小程序版 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. 你会看到:
    • 小程序页面全屏显示浅灰色背景;
    • 一个蓝色立方体自动旋转
    • 立方体有光影立体感,边缘光滑;
    • 完全适配手机屏幕。
相关推荐
不如摸鱼去15 小时前
Wot UI 2.1.0 发布:ConfigProvider 全局配置能力升级
ui·小程序·uni-app
这是个栗子18 小时前
微信小程序开发(九)- uni-app微信小程序商城
微信小程序·小程序·uni-app·vue·vuex
TuCoder19 小时前
景区导览小程序功能选型指南:刚需配置、增值功能与技术避坑要点
小程序
小羊Yveesss1 天前
2026年知识付费小程序多少钱一个?
小程序
一只皮卡皮卡丘1 天前
微信小程序tab页苹果显示安卓不显示的问题
微信小程序·小程序
六月的可乐1 天前
【干货】小程序虚拟瀑布流探索小结
前端·react.js·小程序
GIS数据转换器1 天前
基于3D GIS的监控视频精准标定平台
人工智能·物联网·3d·音视频·无人机·知识图谱
小宋加油啊1 天前
机械臂抓取物体 PVN3D算法调研学习
学习·算法·3d
文阿花2 天前
Echarts实现自动旋转柱状3D扇形图
前端·3d·echarts
前端 贾公子2 天前
小程序蓝牙打印探索与实践(上)
小程序