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 ...
随机推荐
- ChatGPT强势爆红,背后的技术原理是?一文轻松搞懂!
目录 什么是ChatGPT? OpenAI 背后的原理和发展历程 带来的争议和挑战 尾语 作者:小牛呼噜噜 | https://xiaoniuhululu.com 计算机内功.源码解析.科技故事.项目 ...
- Vue进度条组件
1.进度条颜色是渐变的 <template> <div id="progress_bar" ref="myChart"></div ...
- Mybatis-Plus学习
mybatis-plus 学习 系统环境 jdk8+mysql5.7+springBoot+mybatis最新版本+系统编码UTF-8 文件配置 application.properties # 应用 ...
- OOP学习讲义
什么是OOP 场景:我进入一家IT公司,面试官问道我这个问题.OOP?WTF?"众所周知,Java是一门面向对象的开发语言,所以OOP不就是面向对象设计咩.Java把所有的元素都当成是一个对 ...
- C++实现顺序栈相关操作代码
#include<iostream>#include<cstdlib>using namespace std;#define MAXSIZE 100#define OK 1#d ...
- Mybatis的几种传参方式
前言 单个参数 多个参数 使用索引[不推荐] 使用@Param 使用Map POJO[推荐] List传参 数组传参 总结 单个参数 单个参数的传参比较简单,可以是任意形式的,比如#{a}.#{b}或 ...
- Wifi Display
wifi display常用术语 AP:wifi access point Primary Sink: a device that supports rendering video content o ...
- 解决linux conda 命令行环境提示消失的方法
之前不知道这么搞的,一不小心改了conda的默认设置,后面再登录的时候发现环境名字看不见了,用着很难受,为了解决这个问题,后面发现,应该是我改了changeps1这个设置,他默认是开着的,可以用下面的 ...
- MTSC2021上海站PPT 分享
- windows文件夹被占用的解除办法
1.第一步,按下快捷键组合 ctrl alt del,打开任务管理器窗口,点击上方菜单栏中的性能选项. 2. 第二步,在性能页面下找到打开资源监视器按钮并点击. 3. 第三步,进入资源监视器页面,点击 ...