Python Web 3D开发快速入门(python web开发从入门到精通)

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

Python Web 3D开发快速入门(python web开发从入门到精通)

1、什么是PyWeb3D?

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

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

Python Web 3D开发快速入门(python web开发从入门到精通)

2、开发环境安装

无需安装任何东西即可使用 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>

3、需要的准备工作

创建一个文件夹并将其命名为 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 代码所在的 <script type=”text/python”> </script> 标签

4、用Python创建旋转立方体

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

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

from browser import document, windowfrom 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 = 5def 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, windowfrom pyweb3d.pyweb3d import *

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

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

其余内容说明如下:

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

5、运行代码

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

Python Web 3D开发快速入门(python web开发从入门到精通)


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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023年3月17日 上午10:35
下一篇 2023年3月17日 上午10:51

相关推荐

  • 党员管理

    党员管理是中国共产党的重要管理工作之一,关系到党的生死存亡和中国特色社会主义事业的胜利发展。作为一名党员,管理好自己的思想和行动,是保证党员身份的有效体现,也是实现党员价值和使命的…

    科研百科 2024年10月5日
    2
  • 硕士怎么找科研项目

    硕士找科研项目是一个至关重要的过程,能够帮助自己更好地开展研究工作。本文将介绍硕士如何找科研项目的方法。 首先,硕士需要明确自己的研究兴趣和方向。确定研究方向是非常重要的,因为这将…

    科研百科 2025年6月4日
    1
  • uni-app发布android版App的详细过程(uni-app开发安卓app)

    开发环境 1、android studio下载地址:https://developer.android.google.cn/studio/index.html 2、HBuilder…

    科研百科 2023年5月15日
    249
  • 江苏省卫健委科研管理平台

    江苏省卫健委科研管理平台 近年来,随着科技的不断发展,科研管理已经成为医学领域不可或缺的一部分。江苏省卫健委科研管理平台则是江苏省卫健委为了推进医学科研管理工作而搭建的一个平台,它…

    科研百科 2024年10月2日
    144
  • 学生管理系统项目策划案

    学生管理系统项目策划案 随着现代教育的不断发展,学校管理也需要更加智能化和信息化,以提供更好的服务和支持。因此,开发一个高效、易于使用的学生管理系统成为当今教育行业的趋势之一。本文…

    科研百科 2025年1月16日
    1
  • 新建筑项目信息管理系统

    新建筑项目信息管理系统 随着现代建筑行业的快速发展,建筑项目的信息管理也变得越来越重要。为了更好地管理建筑项目,开发一款高效、实用的新建筑项目信息管理系统变得必要。本文将介绍一款新…

    科研百科 2025年1月17日
    2
  • 露营营地科研项目怎么做

    露营是一种令人兴奋和难忘的户外活动,但如果没有科研项目相伴,露营可能会变成一种单调乏味的活动。因此,露营营地科研项目是一种有趣而有意义的方式来探索自然,学习新知识,并提高技能。本文…

    科研百科 2025年5月28日
    0
  • 免费工程项目管理软件

    免费工程项目管理软件: 一个让项目管理更快速,更精确,更自由的软件 随着数字化时代的到来,项目管理已经成为了企业和组织中不可或缺的一部分。传统的手动管理方式已经无法适应快速变化的工…

    科研百科 2024年7月21日
    16
  • 科研项目社会经济效益

    科研项目的社会经济效益 科研项目是推动社会发展的重要力量,不仅促进了科学技术的进步,同时也带来了巨大的社会经济效益。在科研项目中,如何最大化社会经济效益成为研究人员需要考虑的问题。…

    科研百科 2024年10月26日
    12
  • 科技项目攻关、科研成果转化存在的 困难问题及对策建议

    科技项目攻关、科研成果转化面临的困难问题及对策建议 近年来,随着科技的快速发展,科技项目攻关和科研成果转化已经成为科技发展的重要方向。然而,在这个过程中,仍然存在着许多困难问题,这…

    科研百科 2024年10月11日
    267