我有一个 unity webgl 项目和一个 asp.net mvc 项目。
我需要在 View 中显示 webgl 内容。
我首先想到的是简单地复制内容 统一给我的index.html并将其粘贴到.cshtml文件中并更改地址。但是当我这样做时,会弹出不正确的 header 错误。
我是做错了什么还是一切都错了。我应该完全改变我的方法吗?
我还将这些文件扩展名添加到了 web.config
<staticContent>
<!-- Unity 5.x -->
<remove fileExtension=".mem" />
<mimeMap fileExtension=".mem" mimeType="application/octet-stream" />
<remove fileExtension=".data" />
<mimeMap fileExtension=".data" mimeType="application/octet-stream" />
<remove fileExtension=".memgz" />
<mimeMap fileExtension=".memgz" mimeType="application/octet-stream" />
<remove fileExtension=".datagz" />
<mimeMap fileExtension=".datagz" mimeType="application/octet-stream" />
<remove fileExtension=".unity3dgz" />
<mimeMap fileExtension=".unity3dgz" mimeType="application/octet-stream" />
<remove fileExtension=".jsgz" />
<mimeMap fileExtension=".jsgz" mimeType="application/x-javascript; charset=UTF-8" />
</staticContent>
最佳答案
基本上,您将所有文件引用复制到您的 View ,当然还有 Canvas 容器以及初始化它的代码。
添加所有 css 样式文件
@Styles.Render("~/webgl/TemplateData/style.css")
以及所有带有
的 js 文件@Scripts.Render("~/webgl/TemplateData/UnityProgress.js");
所以你会得到类似的东西
@{
ViewBag.Title = "Stage";
@Styles.Render("~/webgl/TemplateData/style.css")
@Scripts.Render("~/webgl/TemplateData/UnityProgress.js");
@Scripts.Render("~/webgl/Build/UnityLoader.js");
}
<h2>Stage</h2>
<script>
var gameInstance = UnityLoader.instantiate("gameContainer", "../webgl/Build/Builds.json", {onProgress: UnityProgress});
</script>
<div class="webgl-content">
<div id="gameContainer" style="width: 960px; height: 600px"></div>
<div class="footer">
<div class="webgl-logo"></div>
<div class="fullscreen" onclick="gameInstance.SetFullscreen(1)"></div>
<div class="title">Figurines</div>
</div>
</div>
不要忘记将 unityweb mime 类型添加到 web.config
<system.webServer>
<staticContent>
<remove fileExtension=".unityweb" />
<mimeMap fileExtension=".unityweb" mimeType="application/octet-stream" />
</staticContent>
</system.webServer>
关于c# - 如何在asp.net mvc View 中使用unity3d webgl内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37760733/