SwiftでmacOS用スクリーンセーバーを作る

Xcodeを利用すれば、実は簡単にスクリーンセーバーが作れます。
用意されているテンプレートはObjective-Cですが、設定すればSwiftで作成可能です。
macOS開発をする機会が少なくとも、iOS開発に親しんでいれば、無理なく進められるかと思います。

開発環境

・Xcode 8.3.3
・macOS Sierra 10.12.6
・Swift 3

テンプレートの準備

まずXcodeで新規プロジェクト作成ダイアログを開き、macOS>Other>Screen Saverを選択し、先に進みます。

スクリーンショット 2017-10-06 17.26.32

 

すると、Objective-Cのテンプレートが作成されますが、
今回はSwiftで書きたいので.mファイルと.hファイルは削除し、代わりに同じ名前で.swiftファイルを作成します。
「Objective-Cと紐付けるためのBridging-headerを作成しますか?」といったダイアログが表示されますが、作成しなくて大丈夫です。

スクリーンショット 2017-10-06 17.27.56

 

Swiftファイルの中身は以下のようにします。
削除したファイルと同様の中身です。これがテンプレートとなります。

メソッド名から大体想像がつくかと思いますが、
init()で初期設定を行い、drawRect()やanimateOneFrame()で描画を行います。

図形の描画

今回は、ランダムな大きさと色で矩形が描画されていくサンプルを作ります。
animateOneFrame()の中に以下のコードを記述します。

ランダムな場所に、ランダムな大きさと色の長方形を1つ描画しています。
このanimateOneFrame()メソッドは1フレーム毎に呼ばれるため、時間経過とともに長方形が画面に広がっていくはずです。

ちなみに、drawRect()の中に書いた場合は本当に1回しか描画されません。

起動準備

では、起動の準備をしましょう。

デバッグのために数秒待つのも面倒なので、スクリーンセーバーをビルドのタイミングで起動できるようにします。
下記ScreenSaver.frameworkの中にあるScreenSaverEngine.appを
アプリケーションディレクトリにコピーします。

・/System/Library/Frameworks/ScreenSaver.framework/Versions/A/Resources/ScreenSaverEngine.app

スクリーンショット 2017-10-06 17.32.10

 

次にSchemeの設定です。Edit Scheme…から以下の画面を開き、
InfoにあるExecutableへ、先ほど追加したScreenSaverEngine.appを設定します。

スクリーンショット 2017-10-06 17.32.37

スクリーンショット 2017-10-06 17.33.27

 

ArgumentsのArguments Passed on Launchに下記を設定します。

・-module “$(EXECUTABLE_NAME)”

スクリーンショット 2017-10-06 18.33.36

 

さらに、作成したものをスクリーンセーバー用のディレクトリにコピーするため、
RunScriptの設定をします。
TARGETS>Build Phasesを開き、左の+ボタン>”New Run Script Phases”と進み、表示されるシェルに下記のコマンドを入力します。

・open -W “${CODESIGNING_FOLDER_PATH}”

スクリーンショット 2017-10-06 17.52.22

 

長かったですが、これで設定完了です!

起動

では、コードをRunしてみましょう。
すると、下記のようにインストールを求められるので許可します。

スクリーンショット 2017-10-06 18.00.05

 

インストールするとスクリーンセーバー設定画面が開きますが、作成しているプロジェクト名のスクリーンセーバーが選択されていることを確認し、閉じます。

スクリーンショット 2017-10-06 18.00.52

 

するとスクリーンセーバーが開始されます!
されない場合は、アプリケーションに追加したScreenSaverEngine.appを起動してください。
もしくはターゲットを macOS 10.9 としてください。
※今回はひたすら矩形が増えていくだけで消えないので注意!

ink

 

最後に

最後までお付き合いいただきありがとうございます。
iOSに比べmacOSのリファレンスは極端に少なく、描画部分など若干つまづく部分もありますが
試してみると楽しいです!簡単にスクリーンセーバーが作成できました。
GLSLの利用も可能なようなので、より高度な表現にも挑戦したいと思います。
情報セキュリティが重要視されている今だからこそ、自分だけのスクリーンセーバーで
周りと差をつけては如何でしょうか。

●この記事を書いた人