游戏
网页游戏编程设计(Python Web 3D开发快速入门)
2023-02-10 20:16   游戏
Python Web 3D开发快速入门网页游戏编程设计(Python Web 3D开发快速入门)

在本文中,我们将学习如何在Python中使用three.js库,而无需编写任何一行 Javascript。我们将使用PyWeb3D,这是一个额外的层,旨在与Brython的three.js轻松交互。

简单地说,PyWeb3D是一个使用Python语法的three.js库。这是一个用Brython和three.js构建的开源项目,它旨在扩展three.js,同时使用python语法与库进行交互。

本文是系列的第一篇,因此我们将保持简单。以下是我们将在本文中创建的内容的示例 ,一个旋转的立方体:

无需安装任何东西即可使用 PyWeb3D。

将必要的库和包添加到 HTML 文件的 标记中:

<script src="https://cdn.jsdelivr.net/npm/brython@3.10.7/brython.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/brython@3.10.7/brython_stdlib.js"></script>
<script src="https://unpkg.com/three@0.145.0/build/three.js"></script>
<script src="https://www.pyweb3d.org/pyweb3d/v1.0.0/pyweb3d.brython.js"></script>

创建一个文件夹并将其命名为 spinning_cube。 这将是我们的工作目录。

在工作目录中,创建一个 index.html 文件。 这是我们所有代码的存放位置。

将以下代码粘贴到index.html 文件中:

<!DOCTYPE html>
<html>
  <head>
	<meta charset="utf-8">
	<title>My first pyWeb3D app</title>
	<script src="https://cdn.jsdelivr.net/npm/brython@3.10.7/brython.min.js"></script>
	<script src="https://cdn.jsdelivr.net/npm/brython@3.10.7/brython_stdlib.js"></script>
	<script src="https://unpkg.com/three@0.145.0/build/three.js"></script>
	<script src="https://www.pyweb3d.org/pyweb3d/v1.0.0/pyweb3d.brython.js"></script>
	<style>
	    body { margin: 0; }
	</style>
 </head>
 <body onload="brython(1)">
	<script type="text/python">
		from browser import document, window
		from  pyweb3d.pyweb3d import *
		...
	</script>
 </body>
</html>

让我们看一下 HTML 文件,特别是 <head></head> 标签和 <body></body> 标签。

head标签

前两个 <script> 标签将加载 Brython — Brython 是用于客户端 Web 编程的 Python 3 实现,旨在取代 Javascript 作为 Web 脚本语言。

第三个 <script> 标签将加载 three.js(Three.js 是一个易于使用、轻量级、跨浏览器的通用 Javascript 3D 库)。

最后一个 <script> 标签将加载 pyweb3d — PyWeb3D 是 three.js,使用 python 语法。

body标签

请注意开始 <body> 标记中的 onload 属性。 这就是我们告诉浏览器在页面加载时调用 brython() 函数的方式。

网页游戏编程设计(Python Web 3D开发快速入门)

最后是我们的 python 代码所在的 <script type=”text/python”> </script> 标签

这就是乐趣的开始。 使用感觉自然的语言。

将以下代码粘贴到 <body> 内的 <script type="text/python"> </script> 中:

from browser import document, window
from  pyweb3d.pyweb3d import *


scene = Scene()
camera = PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 0.1, 1000 )
renderer = WebGLRenderer()

renderer.setSize( window.innerWidth, window.innerHeight )
document.body.appendChild( renderer.domElement )

geometry = BoxGeometry( 1, 2, 1 )
material = MeshBasicMaterial( { 'color': 0x0000ff } )
cube = Mesh( geometry, material )
scene.add( cube )

camera.position.z = 5

def animate(time):
    window.requestAnimationframe( animate )

    cube.rotation.x += 0.11
    # cube.rotation.y += 0.01

    renderer.render( scene, camera )

animate(0)

让我们看一下 Python 代码。

首先导入必要的模块和函数:

from browser import document, window
from  pyweb3d.pyweb3d import *

第一行从 Brython 导入 window和 document实例。

第二行从 pyWeb3D 模块导入所有 three.js 类和函数,这消除了额外的输入和格式化,并使与 three.js 库的交互变得简单。

其余内容说明如下:

从第 5-7 行开始,我们创建了一个场景、相机和渲染器在第 9 行,我们设置要在其上绘制形状的窗口或屏幕的大小在第 10 行,我们将渲染器添加到HTML 正文中从第 12–15 行开始,我们创建了一个盒子形状并将其添加到第 15 行的场景中在第 17 行,我们将相机的位置向后移动,以便我们可以从透视图中看到形状从第 19 到 27 行,我们创建了一个动画循环并在第 27 行调用它。注意传递给动画函数的参数和自变量了吗? 这对于动画工作很重要

在浏览器中打开 index.html,你应该会看到一个美丽的旋转立方体 !

原文链接:
http://www.bimant.com/blog/python-web-3d-crash-tutorial/

网页游戏编程设计(Python Web 3D开发快速入门)

声明:易商讯尊重创作版权。本文信息搜集、整理自互联网,若有来源标记错误或侵犯您的合法权益,请联系我们。我们将及时纠正并删除相关讯息,非常感谢!

您可能感兴趣的...
紫龙新品拿下港澳台iOS畅销榜TOP1,悠星1月收入创新高
2月87个版号来了:王者和梦幻获批,腾讯网易灵犀心动天梯在列
《和平精英》与仙剑的海岛情缘
  • 《和平精英》与仙剑的海岛情缘
  • 2023-02-13分享热度:670...
  • 如果要盘点中国游戏历史,《仙剑奇侠传》(以下简称仙剑)永远是其中绕不过去的一座丰碑。自1995年诞生...
2022年版号重启至今,腾讯、网易等厂商都有哪些游戏获批?
二次元!你的皇帝驾崩了!
  • 二次元!你的皇帝驾崩了!
  • 2023-02-13分享热度:700...
  • 曾经也是风头无两的IP啊!二次元手游,自古以来是各家必争之地,在这个古战场上,玩家们见证了群雄割据...
动视暴雪净利润降44%,微软拥抱ChatGPT市值飙涨
五年空窗,留给Supercell的时间还有多少?
Supercell新作《Squad Busters》能活到引进中国的那一天吗?
原神声优又出事了,提纳里英配骚扰未成年,聊天记录露骨不堪
手机游戏开发的(从“青涩”到“成熟”,浅谈手游发展史)
热门资讯...