小程序版 Three.js 入门 Demo(完整可运行)

第一步:准备项目(前提)

  1. 确保你的小程序项目已安装 threejs-miniprogram

    复制代码
    # 在项目根目录执行
    npm install threejs-miniprogram
    # 然后在微信开发者工具 → 工具 → 构建 npm
  2. 新建 / 替换 pages/index 下的 3 个文件:

第二步:index.wxml(仅需一个 Canvas)

复制代码
<!-- 必须加 type="webgl",小程序 3D 渲染核心 -->
<canvas 
  type="webgl" 
  id="cube-canvas" 
  style="width: 100%; height: 100vh;"
/>

第三步:index.wxss(极简样式)

复制代码
/* 去掉默认边距,让 Canvas 占满屏幕 */
page {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100vh;
}

第四步:index.js(核心代码,逐行注释)

复制代码
// 引入小程序版 Three.js 核心方法
import { createScopedThreejs } from 'threejs-miniprogram';

Page({
  data: {},
  // 页面渲染完成后初始化(小程序生命周期)
  onReady() {
    this.initThreeJS();
  },

  // 初始化 Three.js 核心逻辑
  initThreeJS() {
    // 1. 获取小程序 Canvas 节点(关键:小程序特有)
    const query = wx.createSelectorQuery().in(this);
    query.select('#cube-canvas').node((res) => {
      // 容错:防止 Canvas 获取失败
      if (!res || !res.node) {
        wx.showToast({ title: 'Canvas初始化失败', icon: 'none' });
        return;
      }
      const canvas = res.node;

      // 2. 创建小程序专属 Three.js 实例(核心区别:网页版不用这步)
      const THREE = createScopedThreejs(canvas);

      // 3. 适配高清屏(小程序/手机必备)
      const dpr = wx.getWindowInfo().pixelRatio;
      canvas.width = canvas.width * dpr;
      canvas.height = canvas.height * dpr;

      // ==================== 核心 5 件套(和网页版完全一致) ====================
      // ① 场景:3D 容器
      const scene = new THREE.Scene();
      scene.background = new THREE.Color(0xf0f0f0); // 浅灰色背景

      // ② 相机:透视相机
      const camera = new THREE.PerspectiveCamera(
        75,
        canvas.width / canvas.height, // 宽高比
        0.1,
        1000
      );
      camera.position.z = 5; // 相机后移,能看到立方体

      // ③ 渲染器:绑定 Canvas 节点
      const renderer = new THREE.WebGLRenderer({
        canvas: canvas,
        antialias: true // 抗锯齿
      });
      renderer.setSize(canvas.width / dpr, canvas.height / dpr); // 适配 dpr

      // ④ 创建立方体(几何 + 材质)
      const geometry = new THREE.BoxGeometry(1, 1, 1); // 立方体几何
      const material = new THREE.MeshStandardMaterial({
        color: 0x3498db,    // 蓝色
        metalness: 0.2,     // 轻微金属质感
        roughness: 0.4      // 哑光
      });
      const cube = new THREE.Mesh(geometry, material); // 组合成物体
      scene.add(cube); // 加到场景

      // ⑤ 灯光(必加!否则立方体黑的)
      const ambientLight = new THREE.AmbientLight(0xffffff, 1); // 环境光
      scene.add(ambientLight);
      const directionalLight = new THREE.DirectionalLight(0xffffff, 0.8); // 方向光
      directionalLight.position.set(3, 3, 3); // 灯光位置
      scene.add(directionalLight);

      // ==================== 动画循环(小程序版适配) ====================
      const animate = () => {
        // 旋转立方体
        cube.rotation.y += 0.01;
        cube.rotation.x += 0.01;

        // 渲染场景+相机
        renderer.render(scene, camera);

        // 小程序版 requestAnimationFrame(绑定 Canvas)
        canvas.requestAnimationFrame(animate);
      };
      // 启动动画
      animate();

      // ==================== 页面卸载时销毁资源(小程序性能优化) ====================
      this.onUnload(() => {
        renderer.dispose(); // 销毁渲染器,释放内存
      });
    }).exec();
  }
});

第五步:运行效果

  1. 微信开发者工具中编译项目;
  2. 你会看到:
    • 小程序页面全屏显示浅灰色背景;
    • 一个蓝色立方体自动旋转
    • 立方体有光影立体感,边缘光滑;
    • 完全适配手机屏幕。
相关推荐
不知名的老吴1 天前
CAXA 3D实体设计保姆级下载和安装教程(图文详解)
3d
DisonTangor2 天前
【SIGGRAPH 2026】Pixal3D: 基于图像的像素对齐三维生成
人工智能·3d·开源·aigc
CG_MAGIC2 天前
主流 3D 软件文件互通互导教程
3d·材质·效果图·建模教程·渲云渲染
大江东去浪淘尽千古风流人物2 天前
【Flow4DGS-SLAM】动态环境3DGS-SLAM:光流引导自运动分解与混合4D Gaussian深度解析(CVPR 2026)
3d·slam·vio·光流·动态场景
00后程序员张2 天前
HTTPS单向认证、双向认证、抓包原理与反抓包策略详解
网络协议·http·ios·小程序·https·uni-app·iphone
BY组态22 天前
数字孪生Web3D效果定制呈现|虚实联动,解锁数字化新范式
3d·信息可视化
梦梦代码精2 天前
LikeShop按摩到家系统:2026年本地生活创业新风口,上门服务O2O源码私有化部署实战
大数据·docker·小程序·uni-app·生活·高并发·开源软件
BY组态22 天前
Web3D效果定制|打破平面局限,让数字场景“活”起来
平面·3d·web3
leduo668899o2 天前
商城小程序自由容器支持图片自适应详解:从入门到实战全攻略
小程序
sugar__salt2 天前
从Prompt到3D世界:用大模型精准构建你的迷你村庄
3d·ai·prompt·ai编程