个人项目介绍3:火车站篇

项目需求:

一比一精确显示火车站主建筑和站台模型。实时响应车辆信息(上水,吸污,换乘)并同步显示,实时响应车辆进出站信息,并以动画形式模拟。实时响应报警信息,并能在三位中显示,可拉进处理。显示监控设备内容。

要求:快速迭代,一周内可完成一个火车站的全部功能开发和部署。数据实时显示。保证监控基本无延时。

最终实现:实现平台可配置,可动态调整,数据动态适配。完成公共模型可服用,实现建模,数据对接,视频对接3天完成。基于webrtc实现监控视频基本无延时。

成就:新闻联播有几秒的显示

列车宣传视频有一闪而过的画面

个人网站demo显示效果如下:

个人网站如下:

http://47.96.130.245:8080/train/index.html

 商务合作:

技术实现介绍:

1.获取div

design = document.getElementById('design');

2.初始化 design,renderer,scene,camera,control,gridHelper

//renderer		        	renderer = new THREE.WebGLRenderer({ antialias: true });renderer.setPixelRatio( window.devicePixelRatio );renderer.setSize( design.clientWidth, design.clientHeight );renderer.shadowMap.type=THREE.PCFSoftShadowMap;renderer.gammaInput = true;renderer.gammaOutput = true;renderer.shadowMap.enabled = true;design.appendChild( renderer.domElement );//renderer//scenescene = new THREE.Scene();           //scene//cameracamera = new THREE.PerspectiveCamera( 70,design.clientWidth / design.clientHeight, 1, 10000 );camera.position.set( 0, 100, 100);camera.lookAt( new THREE.Vector3( 0, 0 ,0) );scene.add(camera);//camera	//gridHelpergridHelper = new THREE.GridHelper( 100, 10);scene.add( gridHelper );//gridHelper// add hemi lightsvar hemiLight = new THREE.HemisphereLight( 0xffffff, 0xffffff, 0.05 );hemiLight.color.setHSL( 0.6, 1, 0.6 );hemiLight.groundColor.setHSL( 0.095, 1, 0.75 );hemiLight.position.set( 10000, 10000, 10000 );scene.add( hemiLight );    //controlscontrols = new THREE.TrackballControls( camera,design );controls.rotateSpeed = 2.0;controls.zoomSpeed = 1.2;controls.panSpeed = 0.8;controls.noZoom = false;controls.noPan = false;controls.staticMoving = true;controls.dynamicDampingFactor = 0.3;//controls      

3.导入模型

 var stlmaterial = new THREE.MeshLambertMaterial( { color: 0x012028 ,transparent: true,opacity: 0.5 } );var stlmaterialgl = new THREE.MeshLambertMaterial( { color: 0xff0000  } );var tmparray=new Array("../models/1C.stl","../models/2C.stl","../models/dimian.stl","../models/ding.stl","../models/shoupiaoting.stl","../models/weiqiang.stl","../models/zhantaiguidao.stl",);var i = 0;for(i=0;i<tmparray.length;i++){var loader = new THREE.STLLoader();(function(datatmp,tmpi){loader.load( datatmp, function ( geometry ) {		var mesh = new THREE.Mesh( geometry, stlmaterial );mesh.rotation.x = -Math.PI/2;					scene.add( mesh );				} );})(tmparray[i],i);       }

4.显示效果

以上效果源码:

https://download.csdn.net/download/zzjzmdx/88908813

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/719619.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

#WEB前端(CCS选择器)

1.实验&#xff1a;CCS选择器 2.IDE&#xff1a;VSCODE 3.记录&#xff1a; 子代选择器、后代选择器、相邻兄弟选择器、类选择器、伪元素选择器&#xff08;鼠标悬停&#xff09;、ID选择器、调用选择器&#xff08;全选&#xff09; 4.代码&#xff1a; <!DOCTYPE html…

java generics(泛型)

在定义类、接口和方法时&#xff0c;泛型使类型(类和接口)成为参数。与方法声明中使用的形参非常相似&#xff0c;类型参数为您提供了一种方法&#xff0c;可以用不同的输入重用相同的代码。不同之处在于形式参数的输入是值&#xff0c;而类型参数的输入是类型。 使用泛型有许…

Elasticsearch7.17.7操作geo_point类型数据

目前使用的elasticsearch版本是7.17.7 有一个index&#xff0c;其中mapping的内容如下&#xff1a; {"city" : {"aliases" : { },"mappings" : {"properties" : {"city" : {"type" : "keyword"},"…

嵌入式学习 Day 29

函数: 1.函数的定义 2.函数的调用 3.函数的声明 1.函数传参: 1.赋值传递&#xff08;复制传递&#xff09; 函数体内部想要使用函数体外部变量值的时候使用复制传递 2.全局变量传递 3.地址传递 函数体内部想要修改函数体外部变量值的时候使用地址传递 函数…

代码随想录算法训练营第48天| Leetcode 121. 买卖股票的最佳时机、Leetcode 122.买卖股票的最佳时机II

文章目录 Leetcode 121. 买卖股票的最佳时机Leetcode 122.买卖股票的最佳时机II Leetcode 121. 买卖股票的最佳时机 题目链接&#xff1a; Leetcode 121. 买卖股票的最佳时机 题目描述&#xff1a; 给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一支给定股…

W5300驱动说明

W5300是一款带有硬件协议栈的网络芯片&#xff0c;内部拥有128K的缓存&#xff0c;最大支持8路socket通信&#xff0c;与MCU之间通过16位数据总线通信&#xff0c;通信速度远超W5500之类以SPI作为通信接口的网络芯片&#xff0c;特别适合对高速网络传输有需求的应用。 本次使用…

使用 helm repo add istio添加了一个helm chart repo,如何查看istio的版本呢

1. 添加chart repo helm repo add istio https://istio-release.storage.googleapis.com/charts helm repo update2. 查看版本 helm search repo istio 3. 查看版本详细信息 helm show chart istio/cni 4. 查看某个chart的历史版本 helm search repo <chart-name> --…

【Linux】信号的保存

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;Linux ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 信号在Linux中的保存主要涉及方面 信号的类型&#xff1a; 信号处理程序&#xff1a; 信号的传递和处理&#xff1a; 信号的阻…

面试官:你用过Collections工具类吗?

Collections工具类 1. 常用的 Collections 方法2. 代码示例 Java中的 Collections 工具类提供了一系列静态方法&#xff0c;用于对集合进行各种操作&#xff0c;如排序、查找、替换等。下面我们来看一些 Collections 工具类中常用的API和使用示例。 1. 常用的 Collections 方…

回溯算法套路③排列型回溯+N皇后【基础算法精讲 16】

46 . 全排列 链接 : . - 力扣&#xff08;LeetCode&#xff09; 思路 : 那么怎么确定选了那个数呢? 这里设置一个used表示i选没选过 ; class Solution { public:vector<vector<int>> ans;vector<int> path;void backtrack(vector<int>nums,vect…

2024年【天津市安全员B证】考试内容及天津市安全员B证实操考试视频

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 天津市安全员B证考试内容根据新天津市安全员B证考试大纲要求&#xff0c;安全生产模拟考试一点通将天津市安全员B证模拟考试试题进行汇编&#xff0c;组成一套天津市安全员B证全真模拟考试试题&#xff0c;学员可通过…

《Improving Calibration for Long-Tailed Recognition》阅读笔记

论文标题 《Improving Calibration for Long-Tailed Recognition》 改进长尾识别的校准工作 作者 Zhisheng Zhong、 Jiequan Cui、Shu Liu 和 Jiaya Jia 香港中文大学和 SmartMore 初读 摘要 深度神经网络在训练数据集类别极度不平衡时可能会表现不佳。最近&#xff0c…

pydub、playsound播放声音;gradio、streamlit页面播放声音;gradio 页面图像、视频及调用摄像头

1、pydub from pydub import AudioSegment from pydub.playback import playsong AudioSegment.from_wav(r"C:\Users\loong\Downloads\zh.wav") play(song)2、playsound from playsound import playsoundplaysound(r"voice.wav")3、streamlit import s…

Linux学习:初识Linux

目录 1. 引子&#xff1a;1.1 简述&#xff1a;操作系统1.2 学习工具 2. Linux操作系统中的一些基础概念与指令2.1 简单指令2.2 ls指令与文件2.3 cd指令与目录2.4 文件目录的新建与删除指令2.5 补充指令1&#xff1a;2.6 文件编辑与拷贝剪切2.7 文件的查看2.8 时间相关指令2.9 …

22.基于springboot + vue实现的前后端分离-汽车票网上预定系统(项目 + 论文PPT)

项目介绍 系统是一个B/S模式系统&#xff0c;采用Spring Boot框架&#xff0c;MySQL 数据库设计开发&#xff0c;充分保证系统的稳定性。系统具有界面清晰、操作简单&#xff0c;功能齐全的特点&#xff0c;使得汽车票网上预订系统管理工作系统化、规范化。本系统的使用使管理人…

JavaScript作用域及预解析

文章目录 1. 作用域介绍2. 变量的作用域*3. JS中没有块级作用域4. 作用域链5. 预解析预解析案例 1. 作用域介绍 全局作用域局部作用域相同的变量名称在不同的作用域中是不会相互影响的&#xff01; 2. 变量的作用域 全局变量&#xff1a;在全局下都可以使用&#xff1b;局部变…

蓝桥杯——外卖店优先级

外卖店优先级 题目分析 这一题一看N&#xff0c;M&#xff0c;T的范围就知道不能暴力&#xff0c;要讨巧&#xff0c;怎么讨巧是重点。正常的思路是第一层for循环遍历订单&#xff08;或者外卖店&#xff09;&#xff0c;第二层for循环遍历外卖店&#xff08;或者订单&#x…

Vue中 computed 和 watch

在Vue框架中&#xff0c;computed和watch都用于响应数据的变化&#xff0c;但它们在使用上有着不同的侧重点和机制。具体分析如下&#xff1a; 1. 功能差异 computed是计算属性&#xff0c;它是基于它们的响应式依赖进行缓存的。只有当依赖的数据发生变化时&#xff0c;compu…

2827. 范围中美丽整数的数目

文章目录 题意思路代码 题意 题目链接 思路 按位dp暴力 代码 // 暴力 class Solution { public:int numberOfBeautifulIntegers(int low, int high, int k) {int l low / k;int r high / k;if (low % k)l;int ans 0;while (l < r){int tmp l * k;if (10 < tmp &…

华为数通方向HCIP-DataCom H12-821题库(多选题:61-80)

第61题 ACL 可分为如下哪些类别? A.用户自定义 ACL B.基本 ACL C.二层ACL D.高级ACL 【参考答案】ABCD 【答案解析】 A. 用户自定义 ACL (User-defined ACL): 这是用户根据自身需求自定义的 ACL,用于实现特定的访问控制策略。B.基本 ACL (Standard ACL): 基本 ACL 是基于源 …