ChilloutVRでLuaを使う方法
Luaとはスクリプト言語(プログラミング言語)です。
ChilloutVRにおいては、コンポーネントのみでは難しい挙動や処理を実現できます。
ですが、ChilloutVRでのLua実装はまだ開発中なので、ChilloutVRでLuaを使用するにはベータ版にアクセスする必要があります。
※2024年9月16日時点の情報を基にしています。
ベータ版にアクセスする
ChilloutVR公式のDiscordの-experimental-newsにある以下の投稿から、ベータ版のアクセスコードを入手します。
※Scriptingの方
※投稿を見るには、ChilloutVR公式のDiscordに入っておく必要があります。
Steamのライブラリから、ChilloutVRのプロパティを開きます。
data:image/s3,"s3://crabby-images/610be/610be7273321eecc23416ab9bdcd06f89f78996b" alt=""
「ベータ」タブに移動し、コードを入力し、「コードを確認」を押します。
その後、「オプトイン~」を押します。
data:image/s3,"s3://crabby-images/5cd70/5cd70c5b4f32584218eed766139e6423c355c6e8" alt=""
以下のような表示になります。
data:image/s3,"s3://crabby-images/f7784/f7784b92530918fa3e851622261a2a28dd1ce8b7" alt=""
data:image/s3,"s3://crabby-images/11def/11defbf4de069636ec9b4ea31956ebb35d4c627f" alt=""
Lua環境をセットアップする
Visual Studio Codeをインストールします。
※Visual Studio Codeとは、Luaを記述するためのコードエディターです。
CCKのプロジェクトを開きます。
※事前にCCKのプロジェクトをセットアップしている前提で進めます。
Alpha Blend Interactive->Scripting->Set Up VSCodeを選択します。
data:image/s3,"s3://crabby-images/1c8dd/1c8dd764d2d6b686369457d6f440f88fd7d2d604" alt=""
Visual Studio CodeにLuaの拡張機能をインストールします。
Hello World
ログに「Hello, world!」と表示するPropを作成します。
シーンにCubeを作成します。
data:image/s3,"s3://crabby-images/f37e1/f37e1c4c629bf5d81a796934c0b693a0716b0e97" alt=""
CubeにCVRSpawnableをアタッチします。
data:image/s3,"s3://crabby-images/bcef3/bcef39080355bb122fa0280a053db5a33402a04f" alt=""
CVRLuaClientBehaviourをアタッチします。
data:image/s3,"s3://crabby-images/6b416/6b41661045a57735aca71cb4f6e438de3df2cabf" alt=""
プロジェクト内に「Lua」というフォルダーを作成します。(必須ではありません)
「Lua」フォルダーに「Hello World」というフォルダーを作成します。(必須ではありません)
CVR Lua Scriptを作成します。
data:image/s3,"s3://crabby-images/94c2d/94c2dd1275c6796fd784bdb758e3eee5713e0346" alt=""
名前を「helloworld.lua」にします。
data:image/s3,"s3://crabby-images/76b00/76b006d8c6f7135c49c05a86097531097a3f8580" alt=""
Visual Studio CodeでCCKのプロジェクトのAssetsフォルダーを開きます。
data:image/s3,"s3://crabby-images/0f260/0f260143e2d1ba9196d52c2e9b3dbe46c1c1bd55" alt=""
helloworld.luaに以下の内容を記述します。
-- Start is called before the first frame update
function Start()
print "Hello, world!"
end
-- Update is called once per frame
function Update()
end
helloworld.luaをCVRLuaClientBehaviourのScriptAssetに設定します。
data:image/s3,"s3://crabby-images/d2424/d2424e7446c82c73091498672f22cb8b9fd9d054" alt=""
Propとしてアップロードします。
Propをスポーンすると、
%UserProfile%\AppData\LocalLow\Alpha Blend Interactive\ChilloutVR\Player.log
にログが出力されます。
例:
[Lua] /CVRSpawnable_84df4c4c-f727-44af-b45f-e73e202f80dd_78925301(Clone):Client Lua[CVRSpawnable_84df4c4c-f727-44af-b45f-e73e202f80dd_78925301(Clone)]: print: Hello, world!
※ベータ版(scripting)でないと出力されません。
セキュリティについて
以下の記事のざっくりとしたまとめになります。
クライアントを決して信用しない
改ざんのおそれがあるため
暗証番号ギミックなど
改ざん対策として、暗号ハッシュを使用する
適用範囲
自分のスクリプト内に保持したいコードがある場合は、関数にlocalキーワードを使用する
所持金を増やす関数など
サンプル
※随時追加予定です。
FunnyCube
オブジェクトをランダムな軸で回転させます。
数秒ごとに新しい位置にテレポートします。
-- From scripting team meeting notes:
-- First use case: Cubespin with random start position, random direction, resets after 10s.
UnityEngine = require "UnityEngine"
CCKComponents = require "ABI.CCK"
-- LuaLS/LuaCATS annotations start with three dashes (---)
--- @type UnityEngine.Time
Time = UnityEngine.Time
--- @type UnityEngine.Random
UnityRandom = UnityEngine.Random
ORIGINAL_POSITION = UnityEngine.NewVector3(0, 0, 0)
ROTATION_AXIS = nil
nextBehaviourChange = 0.0
function Start()
-- Seed random noise.
math.randomseed(math.floor(Time.time))
-- Print "Hello world!" to Debug console.
print("Hello world!")
-- Record original position.
ORIGINAL_POSITION = UnityEngine.NewVector3(gameObject.transform.position.x, gameObject.transform.position.y,
gameObject.transform.position.z)
end
function Update()
if Time.realtimeSinceStartup > nextBehaviourChange then
i = math.random(1, 6)
if i == 1 then
ROTATION_AXIS = UnityEngine.NewVector3(1, 0, 0)
elseif i == 2 then
ROTATION_AXIS = UnityEngine.NewVector3(0, 1, 0)
elseif i == 3 then
ROTATION_AXIS = UnityEngine.NewVector3(0, 0, 1)
elseif i == 4 then
ROTATION_AXIS = UnityEngine.NewVector3(-1, 0, 0)
elseif i == 5 then
ROTATION_AXIS = UnityEngine.NewVector3(0, -1, 0)
elseif i == 6 then
ROTATION_AXIS = UnityEngine.NewVector3(0, 0, -1)
end
gameObject.transform.position = ORIGINAL_POSITION + UnityRandom.insideUnitSphere
nextBehaviourChange = Time.realtimeSinceStartup + 10.0
end
if ROTATION_AXIS ~= nil then
gameObject.transform.Rotate(ROTATION_AXIS)
end
end
※サンプルコードから、
--- @type CVR.CCK.CVRSpawnable
spawnable = gameObject.GetComponentInParent("ABI.CCK.Components.CVRSpawnable")
if spawnable ~= nil then
spawnable.ForceUpdate()
end
この部分を削除しないと動きませんでした。
data:image/s3,"s3://crabby-images/307c5/307c5b7cd827445c1414469a0bf2ef43c3a3f7de" alt=""