【微信小程序】【AR】threejs-miniprogram 安装(76/100)

本文介绍了如何配置threejs-miniprogram环境,包括搭建node环境、初始化工程及构建npm的注意事项。还提到了threejs-miniprogram的使用,并预告了未来的AR专题。同时,推荐了自研API调试开发工具SmartApi,详细说明了其开发背景、功能特性以及下载地址。

在这里插入图片描述

配置threejs-miniprogram环境

搭建node环境

初始化node工程

npm init

导入threejs-miniprogram

npm i threejs-miniprogram 

注意:安装threejs-miniprogram 后一定要进行 构建npm 否则引用不生效。由于开发工具和版本的关系可能路径有区别已知路径:工具–构建npm;详情-本地设置–启用npm;

threejs-miniprogram 使用

// pages/ar/ar.js
import getBehavior from './behavior'
import yuvBehavior from './yuvBehavior'
const {renderExample1} =require('./example1')
const {showAR} =require('./threeJSDemos/threeJS_1')
import {createScopedThreejs} from 'threejs-miniprogram'


Page({
  behaviors: [getBehavior(), yuvBehavior],
  /**
   * 页面的初始数据
   */
  data: {
    theme: 'light',
    camera:null,
    scene:null,
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {

  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {
    wx.createSelectorQuery()
    .select('#webgl')
    .node()
    .exec(res=>{
       const canvas=res[0].node;
       const THREE=createScopedThreejs(canvas)
      //  renderExample1(canvas,THREE);
      showAR(canvas,THREE);
    })
    ;
  },
  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

threeJS_1如下:

export function showAR(canvas, THREE) {
  var camera, scene, renderer;
  var cube;
  var sphereMesh;
  init();
  animate();
  function init() {
    //创建相机对象
    camera = new THREE.PerspectiveCamera(100, canvas.width / canvas.height, 1, 1000);
    /**
     * 创建场景对象Scene
     */
    scene = new THREE.Scene();
    scene.background = new THREE.Color(0x000000);
    /**
     * 创建渲染器对象
     */
    renderer = new THREE.WebGLRenderer();
    renderer.setPixelRatio(wx.getSystemInfoSync().pixelRatio);
    renderer.setSize(canvas.width, canvas.height);
    /**
     * 创建网格模型
     */
    var geometry = new THREE.BoxGeometry(10, 10, 10);
    var material = new THREE.MeshBasicMaterial({ color: 0x0000ff });//材质对象Material
    cube = new THREE.Mesh(geometry, material);//网格模型对象Mesh
    scene.add(cube);

    //创建一个球体几何对象
    var sphereGeometry = new THREE.SphereGeometry(5, 5, 5);
    var sphereMaterial = new THREE.MeshBasicMaterial({ color: 0x00ff00 });//材质对象Material
     sphereMesh=new THREE.Mesh(sphereGeometry,sphereMaterial);
    sphereMesh.position.set(10,10,0);
    scene.add(sphereMesh);


    /**
     * 光源设置
     */
    //点光源
    var point = new THREE.PointLight(0xffffff);
    point.position.set(400, 200, 300); //点光源位置
    scene.add(point); //点光源添加到场景中
    //环境光
    var ambient = new THREE.AmbientLight(0x444444);
    scene.add(ambient);

    camera.position.z = 20;

  }
  function animate() {
    cube.rotation.x += 0.02;
    sphereMesh.rotation.x += 0.01;
    cube.rotation.y += 0.01;
    canvas.requestAnimationFrame(animate);
    renderer.render(scene, camera);
  }
}

布局如下:

<!--pages/ar/ar.wxml-->

<view>
  <canvas type="webgl" id="webgl" style="width: 100%; height: 450px" bindtouchend="onTouchEnd">
  </canvas>
</view>

补充一些配置

{
  "usingComponents": {},
  "disableScroll": true,
  "navigationBarTitleText": "AR基础"
}

基本到这了。以后的AR专题会补充一些AR知识

产品推荐

推荐理由

postman在国内使用已经越来越困难:
1、登录问题严重
2、Mock功能服务基本没法使用
3、版本更新功能已很匮乏
4、某些外力因素导致postman以后能否使用风险较大
出于以上考虑因此笔者自己开发了一款api调试开发工具SmartApi,满足基本日常开发调试api需求

官网地址SmartApi

http://www.smartapi.site/

是的,兄弟们,我还是建立了自己的官网!需要下载的大佬直接去官网下载就可以了蛤,顺便看看官网介绍
看下面的简单的
在这里插入图片描述


旧版本已停止维护

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lichong951

你的鼓励决定更新的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值