thirty-two(模型点击展示)react-three-fiber
模型点击蒙版展示
点击展示目的(用户需要看见模型中更加多的内容信息)
使用技术 ThreeJs、React-three-fiber、React-three-drei、React、css
整体思路:
1、在展示模型中点击模型将模型数据和visible信息存储
2、将模型数据和visible数据传入蒙版显示页面
3、蒙版层点击关闭,模型层浮于蒙版层之上
<Canvas orthographic camera={{ zoom: 600 }}>
具体实现:
场景模型中点击
<mesh
onClick={(eve) => {
if (data.name.includes('layer') && !data.name.includes('interlayer01')) {
eve.stopPropagation();
showBox(data);
}
}} >
const showBox = (data: any) => {
setModul(data);
setBoxModulVisible(true);
};
需要蒙版显示
显示与隐藏
import { Clone, useGLTF } from '@react-three/drei';
import { Canvas } from '@react-three/fiber';
import classNames from 'classnames/bind';
import { cloneDeep } from 'lodash-es';
import { useThreeContext } from '../../context/ThreeContext';
import styles from '../../styles/model.module.scss';
const cx = classNames.bind(styles);
const Ge = () => {
const { setBoxModulVisible, boxModulVisible, modul } = useThreeContext();
const copyData = cloneDeep(modul);
delete copyData.position;
delete copyData.rotation;
const { nodes }: any = useGLTF('./box-20.gltf');
const box = nodes[`box-20`];
delete box.position;
delete box.rotation;
return (
<>
{JSON.stringify(copyData) !== '{}' && (
<>
<div
className={cx('show')}
onClick={() => setBoxModulVisible(false)}
style={{ display: boxModulVisible ? '' : 'none' }}
></div>
<div className={cx('content')} style={{ display: boxModulVisible ? '' : 'none' }}>
<Canvas orthographic camera={{ zoom: 600 }}>
<pointLight position={[0, 1, 4]} />
<ambientLight />
<mesh rotation={[0.05, -0.05, 0]}>
<Clone object={copyData} />
</mesh>
<mesh rotation={[0.05, -0.05, 0]} position-y={-0.165} position-x={-0.435}>
<Clone object={box} />
</mesh>
</Canvas>
</div>
</>
)}
</>
);
};
export default Ge;
css样式
底层模板
.show {
width: 100%;
height: 100%;
position: absolute;
z-index: 999999998;
top: 0;
left: 0;
right: 0;
background-color: #000;
opacity: 0.4;
color: #f00;
}
模型层
.content {
z-index: 999999999;
height: 300px;
width: 600px;
position: absolute;
top: 50%;
bottom: 50%;
left: 0;
right: 0;
margin: auto;
background-color: #fff;
}
ps:想要实现的功能基本实现,之前使用antd的modul发现每次渲染出的canvas大小来回变(具体问题还未查明)
thirty-two(模型点击展示)react-three-fiber的更多相关文章
- cesium加载gltf模型点击以及列表点击定位弹窗
前言 cesium 官网的api文档介绍地址cesium官网api,里面详细的介绍 cesium 各个类的介绍,还有就是在线例子:cesium 官网在线例子,这个也是学习 cesium 的好素材. 之 ...
- 手写React的Fiber架构,深入理解其原理
熟悉React的朋友都知道,React支持jsx语法,我们可以直接将HTML代码写到JS中间,然后渲染到页面上,我们写的HTML如果有更新的话,React还有虚拟DOM的对比,只更新变化的部分,而不重 ...
- jquery特效(1)—点击展示与隐藏全文
下班了~~~我把今天整理的一个jquery小特效发一下,个人觉得比较简单,嗖嗖的就写出来了~~~ 下面先来看最终的动态效果: 一.来看一下主体框架程序: <!DOCTYPE html> & ...
- osg fbx模型点击节点,对应节点染色
class CPickHandler :public osgGA::GUIEventHandler { public: CPickHandler(osgViewer::Viewer *viewer) ...
- tp5 商品模型的添加展示
路由 //商品模型展示的路由 Route::get('type','/pyg/good/listType'); //将type_id传送至/pyg/good/addType的路由 Route::get ...
- 《TensorFlow2深度学习》学习笔记(四)对笔记二中的模型增加正确率展示
全部代码如下:(红色部分为与笔记二不同之处) #1.Import the neccessary libraries needed import numpy as np import tensorflo ...
- ThreeJS模型展示为黑色,模型出不来
选取gltf格式时,出现模型为黑色,模型出不来 原因: 我们设计部可能是用maya或者3dmax去做:在模型导出时,没有gltf格式:如果maya或者3dmax导出obj然后导进blender,再导出 ...
- React: 认识React
一.简介 React-Native是Facebook开源的跨平台框架,用于实现前端和原生进行混合开发.React-Native开发可以很好的使用原生UI构建用户界面,与传统的使用WebView相比,不 ...
- 个人关于React的一些理解
##React背景 React是当前前端最火的框架,它的理念思想及构建方法比AngularJS更适合做webApp. 它是由facebook团队研发并开源到社区,所以它有很强大的技术背景,而且它的架构 ...
- React和ES6(二)ES6的类和ES7的property initializer
React与ES6系列: React与ES6(一)开篇介绍 React和ES6(二)ES6的类和ES7的property initializer React与ES6(三)ES6类和方法绑定 React ...
随机推荐
- 使用 Three.js 的 3D 制作动画场景
推荐:将 NSDT场景编辑器 加入你的3D开发工具链. 由于 GSL 语法的复杂性,对于许多开发人员来说 WebGL 是一个未知的领域.但是有了 Three.js,在浏览器中 3D 的实现变得简单.下 ...
- Computed 和 Watch 的区别
1.computed计算属性: 作用:(1)解决模板中放入过多的逻辑会让模板过重且难以维护的问题.例如两个数据的拼接或字体颜色的判断. (2)它支持缓存,只有依赖的数据发生了变化,才会重新计算.例如模 ...
- java语言——跨平台原理,jre,jdk
day1 Java是一种混合的编译运行方式:编译+解释(虚拟机) java的跨平台:在虚拟机中运行(jvm) jdk:jvm,核心类库,开发工具(开发环境) jre:Java的运行环境
- Spring Cloud Alibaba 整合 Seata 实现分布式事务
在Spring Boot单体服务中,添加@Transactional注解就能实现事务.在单体服务中,执行事务都是在同一个数据库下进行.但是随着业务越来越复杂,数据量越来越大会进行分库分表.在微服务场景 ...
- CentOS7.6 添加系统自启脚本
一.编辑脚本 1.在自定义的脚本中添加 # chkconfig: 235 20 80 # chkconfig: 2345 20 80 其中2345是默认启动级别,全部0-6共有7个级别. 0表示:表示 ...
- CSS代码加滤镜将网站变为灰色(完整版)/怎么把网站变为灰色(完整版)
CSS代码加滤镜将网站变为灰色/怎么把网站变为灰色 一.效果图 二.CSS代码 html{ background-color: rgb(238, 242, 245); background-blend ...
- Android 7.0+模拟器Fiddler抓包详细教程 fiddler443问题解决办法
https://blog.csdn.net/qq_43278826/article/details/124291040 [前言] 众所周知,假如设备是android 7.0+的系统同时 ...
- N63050 第十二周运维作业 ansible常用模块介绍未完成
就业和全程班本周学习内容: 二十三.Mysql数据库四 1.MySQL主从复制实现和故障排错(50分钟) 2.MySQL级联复制和主主复制架构实现(51分钟) 3.MySQL的半同步复制和复制过滤器( ...
- tasklist
tasklist是windows下列出进程信息的指令,可配合taskKill来关毕进程 https://learn.microsoft.com/zh-cn/windows-server/adminis ...
- 两步解决php超时问题
tp的报错很模糊,需要自己判断是不是超时问题 首先给Apache的配置文件httpd.conf添加几行: <IfModule mod_fcgid.c> FcgidProcessLifeTi ...