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 ...
随机推荐
- 【NOI2014】随机数生成器
代码 #include<cstdio> using namespace std; typedef long long LL; const int N = 5000; int n , m , ...
- Luogu P1505.[国家集训队]旅游
题解 真真正正是个码农题,不过很套路,熟练就打得很快,不过要用点维护边的信息在 \(\text{LCA}\) 出要注意,不能处理此点的信息 \(Code\) #include<cstdio> ...
- JZOJ 5353. 【NOIP2017提高A组模拟9.9】村通网
题目 为了加快社会主义现代化,建设新农村,农夫约(Farmer Jo)决定给农庄里每座建筑都连上互联网,方便未来随时随地网购农药. 他的农庄很大,有N 座建筑,但地理位置偏僻,网络信号很差. 一座建筑 ...
- DrCush_082020_血清阴性RA确诊延迟
转自Dr Jack Cush的Twitter (2020-08-20) 梅奥诊所:血清阴性RA的诊断存在延迟-血清阴性的首次关节肿胀距RA确诊为187天,而血清阳性者则为11天(P <.001) ...
- NSDT可编程3D场景
推荐:将 NSDT场景编辑器 加入你的3D开发工具链. NSDT编辑器简化了WebGL 3D应用的开发,完全兼容Three.JS生态.本文介绍如何在自己的应用中嵌入使用NSDT编辑器搭建的3D场景,并 ...
- FTP调优
最近在解决客户的问题时接触到了一些FTP的问题,自己在使用过程中发现了很多问题,所以这里总结了一些调优的办法: 服务:vsftp 非常安全文件传输 配置文件:/etc/vsftpd/vsftpd.co ...
- Java内存分析利器——Eclipse Memory Analyzer工具的使用
一.如何下载Java程序的dump内存文件并离线导入到MemoryAnalyser工具进行分析 1.jps查看Java应用的pid jps 11584216168084 Launcher24792 ...
- SAP BW/4HANA学习笔记2
2.Data Modeling BW/4HANA Data Modeling简介 Data Quality:数据质量问题: silos(桶仓):大量重复冗余的主数据,独立计算统计: 数据silos缺点 ...
- 力扣(leetcode)题库0001-python3
试一下leetcode的题库,不知道对于我这种小白要多长时,但是目标已经种下,去做就是了.You can do anything you set your mind to. 题目:题库链接 中:给定一 ...
- swagger TypeError: Failed to fetch
最近开发一个项目,项目接口规范是swagger,初次使用swagger遇见很多问题,通过写博记录在项目中遇见的swagger各种情况 我项目中解决方法: 改为: 需要与自己在laravel 框架中e ...