久々にnaninovelの記事など。ちょっとややこしいんですが、naninovelでは選択肢を画像にし、画像をクリックで次の処理を実行させることができます。
選択肢の仕様
前提となる選択肢(@Choice)の使い方についてはこちらで解説してます。
プレハブをコピペ
data:image/s3,"s3://crabby-images/91ee9/91ee907a5fd2570b221f442628697ec5b36ed9a0" alt="1"
ではやってきたいと思います。
まずはNaninovelのAssets/ResourcesにChoiceHandlersフォルダを作っておきます。
まずはNaninovelのAssets/ResourcesにChoiceHandlersフォルダを作っておきます。
data:image/s3,"s3://crabby-images/6ccde/6ccde555c727029660c731dc1eba66f9e03e8bdf" alt="0"
Assets→Naninovel→Prefabs→ChoiceHandlersの中にあるChoiceHandlerButtonをコピーし、
data:image/s3,"s3://crabby-images/b9854/b9854bb9a6d093c7b11d5bfcdb179f1ffe062949" alt="2"
作ったChoiceHandlersフォルダにペースト、
data:image/s3,"s3://crabby-images/1fd8f/1fd8f83c260d6cbdb52ead054639202aae0f7a54" alt="3"
名前を好きに変更します。ここではCustomButtonとしました。基本選択肢に使う画像ごとにこれを作っていくことになります。
data:image/s3,"s3://crabby-images/8eb4c/8eb4c59814c4899b87d800a1fb6e4b543576b183" alt="4"
ダブルクリックしてプレハブを選択、
data:image/s3,"s3://crabby-images/f8ac4/f8ac4e92f64f6aee26c117dc0c7dabd22526891b" alt="5"
Textが選択されてることを確認して、
data:image/s3,"s3://crabby-images/fcd0e/fcd0ea8db613140049d3b6d1a23f8819cdfbe5a2" alt="6"
Textを削除します。
画像の指定
data:image/s3,"s3://crabby-images/32076/3207628586637b9f9454858cf2183ee8e2775a21" alt="9"
NaninovelのResource内に画像を保存しておき、
data:image/s3,"s3://crabby-images/7e9fb/7e9fb534558f1801355a41ccedbc05c3b39a012b" alt="8"
プレハブinspecterのSourceImage〇をクリック、
data:image/s3,"s3://crabby-images/9060d/9060df21d6da06066715104ce733fe3e029cdb2d" alt="10"
使う画像を選択して×を押します。
data:image/s3,"s3://crabby-images/c0f15/c0f154e5d25d1a570f5fe2e66553ccce11e2b0ad" alt="12"
色を白にしてやると、
data:image/s3,"s3://crabby-images/74fd1/74fd183d064970d211dc9d6e2ab3c482baf47b61" alt="13"
つぶれてますが、プレハブに画像が反映されます。
data:image/s3,"s3://crabby-images/b5b7f/b5b7f3845373cd42b4ac8741df3d97224fbd6a5a" alt="14"
サイズを直接指定するか、
data:image/s3,"s3://crabby-images/0386d/0386de53481f1560f7b3b21392aac8ce32e35501" alt="16"
Set Native Sizeを指定するなどして、画像を整えます。
data:image/s3,"s3://crabby-images/8e717/8e717c217feb834e321604e7fa79210084b86374" alt="17"
さらにPreserve Aspectをクリックすると、選択肢表示時にアスペクト比が保持されるようになります。
data:image/s3,"s3://crabby-images/a0635/a0635cbdda813456cf7c94bbef10d44860dbc8db" alt="11"
あとはButtonのTransitionをNoneかSprite Swap(押したときなど設定するならこっちっぽい)に設定しておきます。
スクリプトの設定
;Naninovel
;main.nani
@choice 選択肢テスト goto:ikisaki handler:ButtonList button:ChoiceHandlers/CustomButton
@stop
;ikisaki.nani
到着した
@stop
テストスクリプトを作成し、@Choiceの後ろにhandler:ButtonListおよびbutton:ChoiceHandlers/ボタン名のように入力します。
data:image/s3,"s3://crabby-images/c4f03/c4f03e7e79226cc53002c12f72327aa092d9e8b3" alt="18"
実行すれば選択肢のかわりに画像が表示され、
data:image/s3,"s3://crabby-images/d3f8a/d3f8a7e5dbcfde3ba057733c41c6133e5a92bf38" alt="19"
クリックすると処理が実行されることが確認できます。
テキストを生かす場合
data:image/s3,"s3://crabby-images/38198/38198dc38684c9d61154b1137d6e4ed9648a6cab" alt="21"
Textを削除せず、画像+テキストの形式で使うことも可能です。
data:image/s3,"s3://crabby-images/03261/032619f09c0f0d5b52720c786f90a154ec569ce6" alt="22"
フォント、色などもinspecterで変更可能。
位置の指定
data:image/s3,"s3://crabby-images/a8006/a8006a64c5c427c28e7bbd47190f26db7700343d" alt="20"
初期設定だと、選択肢の位置は自動的に決定され、選択肢の数によって位置が変わります。
;Naninovel
@choice 選択肢テスト goto:ikisaki handler:ButtonArea pos:0,0 button:ChoiceHandlers/CustomButton
@choice 300,0 goto:ikisaki handler:ButtonArea pos:300,0 button:ChoiceHandlers/CustomButtonText
@choice 0,300 goto:ikisaki handler:ButtonArea pos:0,300 button:ChoiceHandlers/CustomButtonText
@stop
位置を指定するにはhandler:ButtonListをButtonAreaにし、posで位置を指定します。
0,0で中心、左の数字が大きいほど右に移動、右の数字が大きいほど上に移動します。
0,0で中心、左の数字が大きいほど右に移動、右の数字が大きいほど上に移動します。
data:image/s3,"s3://crabby-images/d8e04/d8e0490e4f04d81aa1e9fa95eac11c27b975cf37" alt="23"
実行結果です。
data:image/s3,"s3://crabby-images/50184/50184014560c3429c7fe185575dabf459e3910fa" alt=""
やりたいことから逆引きするUNITYの使い方まとめ
Unityをやりたいことから学習していけるよう、機能・用途別にまとめたページです。C#の命令別の逆引きは現時点で作っていません。2019の時期に書き始めているので、それより前のバージョンについては言及しません。
コメント