Jest inny sposób na uzyskanie obrazu, wykonując zrzut ekranu z bieżącą tapetą.
extension NSImage {
static func desktopPicture() -> NSImage {
let windows = CGWindowListCopyWindowInfo(
CGWindowListOption.OptionOnScreenOnly,
CGWindowID(0))! as NSArray
var index = 0
for var i = 0; i < windows.count; i++ {
let window = windows[i]
// we need windows owned by Dock
let owner = window["kCGWindowOwnerName"] as! String
if owner != "Dock" {
continue
}
// we need windows named like "Desktop Picture %"
let name = window["kCGWindowName"] as! String
if !name.hasPrefix("Desktop Picture") {
continue
}
// wee need the one which belongs to the current screen
let bounds = window["kCGWindowBounds"] as! NSDictionary
let x = bounds["X"] as! CGFloat
if x == NSScreen.mainScreen()!.frame.origin.x {
index = window["kCGWindowNumber"] as! Int
break
}
}
let cgImage = CGWindowListCreateImage(
CGRectZero,
CGWindowListOption(arrayLiteral: CGWindowListOption.OptionIncludingWindow),
CGWindowID(index),
CGWindowImageOption.Default)!
let image = NSImage(CGImage: cgImage, size: NSScreen.mainScreen()!.frame.size)
return image
}
}
To podejście wygląda na znacznie prostsze IMHO, jeśli potrzebujesz obrazu, a nie adresu URL.
Należy zauważyć, że tapeta nie jest już zdefiniowana w pliku com.apple.dektop: począwszy od Mavericks ustawienie zostanie przeniesione do folderu ~/Library/Application Support/Dock/desktoppicture.db. To jest plik SQLite, a tabela "danych" zawiera adres URL.
Otworzyłem https://openradar.appspot.com/radar?id=5782854294306816, ponieważ byłoby lepiej, gdyby API zrobiło to, co obiecuje. –