Swift #selectorと@objc func

Swift #selectorと@objc func

Swiftを使っていると必ずSelector引数で渡すファンクションが出てきます。Selectorはstructなのですがここに@objc関数を渡す場合#selector()に包んで渡す必要があるようです。引数にわたす場合#selector(funcName(_:))こんな感じに関数を入れればいいのですが 渡された側はどのように処理をしているのか調べてみました。

class TObject: NSObject {
    override init() {
        super.init()
    }
    @objc func a(_ :Any) {
        print("function a")
    }
    func b(_ f:Selector){
        self.perform(f)
    }
}
let a1 = TObject()
a1.b(#selector(a1.a(_:)))

TObjectというオブジェクトを作成しa と bの関数を作っています。aの関数は@objcです。最後の2行で実行します。b()にaの関数を入れてb()の中のperform(f)でa()を実行しprint(“function a”)を呼んでいます。NSButtonのaction: Selector?もこのように実行されているのかな

Swift macOS kCGWindowNameが出ない場合

Swift macOS kCGWindowNameが出ない場合

macOSアプリで、起動中の他のアプリ(Windw)の状態を列挙したい場合CGWindowListCopyWindowInfo()を使えば macOS上で起動しているWindowなどが列挙できます。下記はコード例です。

if let enumWindows = CGWindowListCopyWindowInfo([.optionAll], 0) {
	for windowInfo in enumWindows as NSArray {
		if let info = windowInfo as? NSDictionary {
			print("\(info)")
		}
	}
}

上記コードで、kCGWindowNumber・kCGWindowOwnerName・kCGWindowOwnerPID・kCGWindowBoundsなどの情報を取得することができます。しかし、kCGWindowNameは取得できないようです。kCGWindowNameを取得したい場合は、macOSの[システム環境設定|セキュリティーとプライバシー|画面収録]に開発中のアプリを登録することで、取得可能になります。

[システム環境設定|セキュリティーとプライバシー]
[システム環境設定|セキュリティーとプライバシー]
func getWindowText(_ windowInfo: NSDictionary) -> String {
	let windowName = windowInfo["kCGWindowName"]
	if (windowName != nil) {
		let windowText: String = windowName as! NSString as String
		return windowText
	} else {
		return ""
	}
}

func enumWindows() {
	if let enumWindows = CGWindowListCopyWindowInfo([.optionAll], 0) {
		for windowInfo in enumWindows as NSArray {
			if let info = windowInfo as? NSDictionary {
				let strWindowText:String = getWindowText(info)
				if (strWindowText.count > 0)  {
					print(strWindowText)
				}
			}
		}
	}
}

2022 MJELD TECHNOLOGIES. ALL RIGHTS RESERVED