はじめに
ゲームを作成しているとウェブブラウザに遷移することなく、ゲームないにウェブビューを表示したいことがあります。
そこで今回はWebViewを実装する方法を紹介しようと思います。
利用するプラグインはGREEの方が作ったunity-webviewを利用します。
GitHub - gree/unity-webview
Contribute to gree/unity-webview development by creating an account on GitHub.
環境
- Unity 2020.2.2f1
- unity-webview 1.0.0
実装方法
今回はGREEの方が作ったプラグインunity-webviewを使用します。
GitHubを確認
バージョンによって実装方法が異なったりするので、詳しくはGitHubを確認してください。
data:image/s3,"s3://crabby-images/f5bdd/f5bdd22a2531221127a7adc84b0c6ba57a0dc0e6" alt=""
manifest.jsonにunity-webviewを追記
次にUnityプロジェクト配下のPackages/manifest.jsonをVisual Studio Code等のテキストエディターで開きます。
その後、「“net.gree.unity-webview”: “https://github.com/gree/unity-webview.git?path=/dist/package”」を追記します。
JSON形式なので、前後の「,」には気をつけてください。
"com.unity.modules.wind": "1.0.0",
"com.unity.modules.xr": "1.0.0",
"net.gree.unity-webview": "https://github.com/gree/unity-webview.git?path=/dist/package"
}
}
data:image/s3,"s3://crabby-images/68f0c/68f0c4fa97cbaadabc94e31dc080ae2a8c861bbd" alt=""
追記前
data:image/s3,"s3://crabby-images/248ba/248ba2d204b37c852f55c0f08a08c309c705d069" alt=""
追記後
data:image/s3,"s3://crabby-images/03747/03747ef04662726859f9b2abcb8dc6d4a2f40f41" alt=""
読み込みが終わるとUnity Package Managerに表示されるようになります。
サンプルコード
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Networking;
using UnityEngine.UI;
public class SampleSceneController : MonoBehaviour
{
[SerializeField] private Button button;
private WebViewObject webViewObject;
// Start is called before the first frame update
void Start()
{
button.onClick.AddListener(OnButtonClicked);
webViewObject = (new GameObject("WebViewObject")).AddComponent<WebViewObject>();
webViewObject?.Init(
enableWKWebView: true
);
}
private void OnButtonClicked()
{
webViewObject?.LoadURL("https://www.google.com/");
webViewObject?.SetVisibility(true);
}
}
動作
data:image/s3,"s3://crabby-images/e23e8/e23e804a1cd6c07f7b9b225d23e7fb2aecba92c7" alt=""
ボタンを押すと。。。
data:image/s3,"s3://crabby-images/01caf/01caff99df290ceaadfc9898e53145389d128001" alt=""
無事表示されました!!
さいごに
ものすごく簡単に実装できました。作ってくれたGREEの方に感謝です。
是非、実装してみてください。
また、よく使いそうなWebViewの見た目のやり方は以下にまとめてあります。
コメント