当前位置: 首页 > wzjs >正文

寻找专业网站建设中国网建设频道

寻找专业网站建设,中国网建设频道,海报制作哪个软件好,龙岗做企业网站嗨,我是小路。今天主要和大家分享的主题是“vuethreeJs 创建多色几何体加载obj模型跳转ojb模型中心”。 项目案例示意图 1.创建网格 定义:创建辅助网格主要用以下方法执行,其中有四个参数 new THREE.GridHelper(大小,分…

        嗨,我是小路。今天主要和大家分享的主题是“vue+threeJs 创建多色几何体+加载obj模型+跳转ojb模型中心”。        

项目案例示意图

1.创建网格

定义:创建辅助网格主要用以下方法执行,其中有四个参数

new THREE.GridHelper(大小,分割段数,中心线轴颜色,网格颜色)
属性列表列表说明
size大小

divisions

分割段数

colorCenterLine

颜色中心线

colorGrid

颜色网格

2.加载obj模型并调整模型中心

定义:获取模型中心,需用用到box3中的getCenter来获取。

const group = new THREE.Group();
const manager = new THREE.LoadingManager();const loader = new OBJLoader(manager);loader.load('./models/model.obj', function (object) {// 计算几何体中心const box = new THREE.Box3().setFromObject(object);const center = box.getCenter(new THREE.Vector3());console.log('obj', object);// 将模型几何顶点平移到中心点位置object.position.set(-center.x, -center.y, -center.z);object.position.y = 100;//然后将模型套入groupgroup.add(object);scene.add(group);})

二、实例代码

<!--加载obj-->
<template><div class="pageBox"><div class="leftBox" ref="leftRef"></div></div></template>
<script setup>
import { onMounted, onUnmounted, reactive, ref } from 'vue';
import * as THREE from 'three';
// 引入轨道控制器扩展库OrbitControls.js
import { OrbitControls } from 'three/addons/controls/OrbitControls.js';
import { getRandomColor, createLight } from '../utils/commonThree';
import { OBJLoader } from "three/addons/loaders/OBJLoader.js";
const leftRef = ref();
// 定义相机输出画布的尺寸(单位:像素px)
let width = window.innerWidth; //宽度
let height = window.innerHeight; //高度
// 创建3D场景对象Scene
const scene = new THREE.Scene();
//设置背景色
scene.background = new THREE.Color(0x646d59);const camera = new THREE.PerspectiveCamera(45, width / height, 1, 10000);
//三角形缩放过大时,会形成多种三角形形成的背景图
camera.position.x = 100;
camera.position.y = 300;
camera.position.z = 600;camera.up.x = 0;
camera.up.y = 1;
camera.up.z = 0;
camera.lookAt({x: 0,y: 0,z: 0
});// 创建渲染器对象
const renderer = new THREE.WebGLRenderer();let tubes = [];
let objMesh;
const group = new THREE.Group();
const createObj = () => {const manager = new THREE.LoadingManager();const loader = new OBJLoader(manager);loader.load('./models/model.obj', function (object) {// 计算几何体中心const box = new THREE.Box3().setFromObject(object);const center = box.getCenter(new THREE.Vector3());console.log('obj', object);// 将模型几何顶点平移到中心点位置object.position.set(-center.x, -center.y, -center.z);object.position.y = 100;//然后将模型套入groupgroup.add(object);scene.add(group);})const geometry = new THREE.BoxGeometry(30, 30, 30);console.log(geometry);const material = [new THREE.MeshBasicMaterial({color: getRandomColor()}),new THREE.MeshBasicMaterial({color: getRandomColor()}),new THREE.MeshBasicMaterial({color: getRandomColor()}),new THREE.MeshBasicMaterial({color: getRandomColor()}),new THREE.MeshBasicMaterial({color: getRandomColor()}),new THREE.MeshBasicMaterial({color: getRandomColor()}),];const tube = new THREE.Mesh(geometry, material);tube.position.set(0, 0, 0);return tube;
}onMounted(() => {initData()//添加相机空间const controls = new OrbitControls(camera, renderer.domElement);// 如果OrbitControls改变了相机参数,重新调用渲染器渲染三维场景controls.addEventListener('change', function () {renderer.render(scene, camera); //执行渲染操作});//监听鼠标、键盘事件renderer.setSize(width, height); //设置three.js渲染区域的尺寸(像素px)//将innerHTML置空,避免append重复添加渲染leftRef.value.innerHTML = ''leftRef.value.append(renderer.domElement);})
let outSphere;
const initData = () => {createLight(scene, 100, 100, 200);outSphere = createObj();scene.add(outSphere);//创建网格辅助线const helper = new THREE.GridHelper(1000, 50, getRandomColor(), getRandomColor());console.log('helper', helper);scene.add(helper);render();
}
function render() {requestAnimationFrame(render);group.rotation.y += 0.01;outSphere.rotation.y += 0.01;renderer.render(scene, camera);
}
onUnmounted(() => {//释放内存renderer.dispose();
})</script>
<style scoped lang="less">
.pageBox {width: 100%;height: 100vh;padding: 0;margin: 0;display: flex;justify-content: space-between;align-items: center;.rightBox {width: 100%;height: 100%;}
}
</style>

三、总结

       1、主要注意模型中心位置的调整。目前主要的思路是将obj模型移动到其中心点的位置,然后将其用group包裹,然后让group绕自身旋转。

        2、加载obj模型时,需要用loadManager这个方法进行加载。

        3、obj模型和gltf模型有很大的不同,gltf有scene,但obj没有。两个方法不同用同一个使用;

都看到这里了,记得【点赞】+【关注】哟。

参考文章:

vue+threeJs 在开发中将部分常用的代码模块封装-CSDN博客


文章转载自:

http://FEvmdFVv.wzknt.cn
http://e36EsrEx.wzknt.cn
http://zZmgfr4L.wzknt.cn
http://hvGqnbhX.wzknt.cn
http://MJJ9Wb3x.wzknt.cn
http://jNXrDqLY.wzknt.cn
http://CwvlREYF.wzknt.cn
http://5LQ3ElPg.wzknt.cn
http://rST0VbNe.wzknt.cn
http://dnmyyKlb.wzknt.cn
http://hxLL04hd.wzknt.cn
http://1aoRt7Gg.wzknt.cn
http://GTNKHs0i.wzknt.cn
http://q8ngl2wj.wzknt.cn
http://NgqcSXhJ.wzknt.cn
http://NTazEB6N.wzknt.cn
http://dkyjHMrT.wzknt.cn
http://NluQ8zLM.wzknt.cn
http://IfHgP1wA.wzknt.cn
http://L0PmJqrn.wzknt.cn
http://jQWLE6XW.wzknt.cn
http://6jdCyShb.wzknt.cn
http://rBAyFVRP.wzknt.cn
http://f1qrjXiQ.wzknt.cn
http://9GJZkTCl.wzknt.cn
http://SSH9bB9U.wzknt.cn
http://YHa4qwNL.wzknt.cn
http://dYRhmfO7.wzknt.cn
http://z2hXrfSg.wzknt.cn
http://8crka2E2.wzknt.cn
http://www.dtcms.com/wzjs/779226.html

相关文章:

  • 深圳如何建立公司自己网站商城网站做推广有什么好处
  • 住房和城乡建设部网站投诉电话芜湖尚格网络科技有限公司
  • 网站制作多少钱新闻沈阳网上注册公司流程
  • 网站建设方面的wordpress固定连接怎么设置最好
  • 伊春网站制作哪个网站能学做微商
  • 网站开发视频教程下载重庆招聘网站哪个好
  • 雄安专业网站建设哪家好中山建网站多少钱
  • 企业所得税怎么算例题系统优化的影响因素
  • 被称为网站开发神器工信网站投诉系统
  • 招商网站搭建费用导航网
  • 做个小网站多少钱郑州网约车官网
  • 给公司做网站多少钱网站开发定制模板网站建设
  • 可以做360度全景图的网站茌平网页设计
  • 蓝色科技企业网站模板免费下载wordpress静态设置
  • 重庆网站推广优化软件业务在网站上投放广告
  • 石排镇网站建设微信里的网站怎么做
  • 天津公司建站如何做网站关键词优化
  • 怎么在阿里云上做网站类似凡科网的网站
  • 流行网站开发框架房地产网站建设哪家有效果
  • 德州网站优化优设计网站
  • 做个外贸网站多少费用科技团队网站
  • 网站建设工作量评估智能网站建设步骤
  • html5网站后台管理系统互联网网站建设收费
  • 网络营销渠道的概念乐山网站seo
  • 重庆做网站 外包公司有哪些做网站功能需要注意什么
  • 公司设计网站推荐四川建设厅网站招聘
  • 网站建设衤首选金手指10做网站有什么关于财务的问题
  • 哪里有卖自己做的网站成都那家做网站好
  • 钻戒网站建设需求龙之向导外贸网站网址
  • 做网站的常识rt-theme 18 wordpress