当前位置: 首页 > 知识库问答 >
问题:

javascript - 请问大佬们,车辆模型在渲染的时候是一闪一闪的渲染出来?

容柏
2023-08-15
  // 接收websocket数据  const onMessage = async (event) => {    const data = JSON.parse(event.data);    if (data.data == undefined) {      console.log('未响应');    } else {      processPositionParams(data.data);    }  };  // 封装处理位置参数的函数  const positionParams = []; // 用于存储所有的位置参数数据  const bufferLimit = 50; // 缓冲区大小限制,可以根据需求调整  function processPositionParams(data) {    const targetingTypes = {      0x10: 'RTK',      0x11: 'UWB',      0x12: '融合'    };    const newPositionParam = {      TargetingType: targetingTypes[data.type],      UID: data.uid,      Angle: data.angle,      Height: data.height,      longitude: data.longitude,      latitude: data.latitude    };    positionParams.push(newPositionParam);    // 超过缓冲区大小限制时移除最旧的位置参数数据    if (positionParams.length > bufferLimit) {      positionParams.shift();    }    const labelText = `终端ID:${data.uid},定位类型:${targetingTypes[data.type]}\n经度:${data.longitude},纬度:${data.latitude}\n角度:${data.angle},高度:${data.height}`;    CarModel(positionParams, newPositionParam.Angle); // 车辆模型    pointPolyline(positionParams, labelText) // 轨迹点和轨迹线  }// 车辆模型let carModelData = [];function CarModel(positions, angle) {  const headingPitchRoll = new Cesium.HeadingPitchRoll(    Cesium.Math.toRadians(110),    Cesium.Math.toRadians(0),    Cesium.Math.toRadians(0)  );  const scaleByDistance = new Cesium.NearFarScalar(200, 120, 1200, 0.6);  const distanceDisplayCondition = new Cesium.DistanceDisplayCondition(0, 10000);  for (const position of positions) {    let entityIndexs = carModelData.length;    const cartesian3 = Cesium.Cartesian3.fromDegrees(position.longitude, position.latitude, 0.4);    const CarModelMove = viewer.entities.add({      position: new Cesium.CallbackProperty(() => {        return cartesian3;      }, false),      orientation: Cesium.Transforms.headingPitchRollQuaternion(cartesian3, headingPitchRoll),      model: {        uri: "http://127.0.0.1:5501/car/scene.gltf",        show: new Cesium.CallbackProperty(() => {          return entityIndexs === carModelData.length - 1;        }, false),        color: Cesium.Color.CORAL,        scale: 75,        scaleByDistance,        distanceDisplayCondition,      },    });    carModelData.push(CarModelMove);  }}

图片.png
图片.png

共有2个答案

萧星火
2023-08-15

为啥每一次从后台拿到数据后要再次调用CarModel呢?
这个初始化车辆模型的方法不是全局调用一次就好了嘛?车辆的position是一个callback,那么后续只要改变cartesian3的值即可。
而且这个CarModel方法还是在for循环positons的时候调用的,岂不是每次数据一来就至少渲染50次车辆?车辆频繁销毁+创建,肯定是会闪烁呀。

// 接收websocket数据const onMessage = async (event) => {  const data = JSON.parse(event.data);  if (data.data == undefined) {    console.log('未响应');  } else {    processPositionParams(data.data);  }};const cartesian3 = undefined;// 封装处理位置参数的函数const positionParams = []; // 用于存储所有的位置参数数据const bufferLimit = 50; // 缓冲区大小限制,可以根据需求调整function processPositionParams(data) {  const targetingTypes = {    0x10: 'RTK',    0x11: 'UWB',    0x12: '融合',  };  const newPositionParam = {    TargetingType: targetingTypes[data.type],    UID: data.uid,    Angle: data.angle,    Height: data.height,    longitude: data.longitude,    latitude: data.latitude,  };  positionParams.push(newPositionParam);  // 超过缓冲区大小限制时移除最旧的位置参数数据  if (positionParams.length > bufferLimit) {    positionParams.shift();  }  const labelText = `终端ID:${data.uid},定位类型:${    targetingTypes[data.type]  }\n经度:${data.longitude},纬度:${data.latitude}\n角度:${data.angle},高度:${    data.height  }`;  if (positionParams.length === 1) {    addCar();  } else {    changeCarPosition(positionParams[positionParams.length - 1]);  }  //CarModel(positionParams, newPositionParam.Angle); // 车辆模型  pointPolyline(positionParams, labelText); // 轨迹点和轨迹线}// 车辆模型let carModelData = [];function CarModel(positions, angle) {  const headingPitchRoll = new Cesium.HeadingPitchRoll(    Cesium.Math.toRadians(110),    Cesium.Math.toRadians(0),    Cesium.Math.toRadians(0)  );  const scaleByDistance = new Cesium.NearFarScalar(200, 120, 1200, 0.6);  const distanceDisplayCondition = new Cesium.DistanceDisplayCondition(    0,    10000  );  for (const position of positions) {    let entityIndexs = carModelData.length;    const cartesian3 = Cesium.Cartesian3.fromDegrees(      position.longitude,      position.latitude,      0.4    );    const CarModelMove = viewer.entities.add({      position: new Cesium.CallbackProperty(() => {        return cartesian3;      }, false),      orientation: Cesium.Transforms.headingPitchRollQuaternion(        cartesian3,        headingPitchRoll      ),      model: {        uri: 'http://127.0.0.1:5501/car/scene.gltf',        show: new Cesium.CallbackProperty(() => {          return entityIndexs === carModelData.length - 1;        }, false),        color: Cesium.Color.CORAL,        scale: 75,        scaleByDistance,        distanceDisplayCondition,      },    });    carModelData.push(CarModelMove);  }}function addCar() {  const headingPitchRoll = new Cesium.HeadingPitchRoll(    Cesium.Math.toRadians(110),    Cesium.Math.toRadians(0),    Cesium.Math.toRadians(0)  );  const scaleByDistance = new Cesium.NearFarScalar(200, 120, 1200, 0.6);  const distanceDisplayCondition = new Cesium.DistanceDisplayCondition(    0,    10000  );    const CarModelMove = viewer.entities.add({    position: new Cesium.CallbackProperty(() => {      return cartesian3;    }, false),    orientation: Cesium.Transforms.headingPitchRollQuaternion(      cartesian3,      headingPitchRoll    ),    model: {      uri: 'http://127.0.0.1:5501/car/scene.gltf',      show: new Cesium.CallbackProperty(() => {        return entityIndexs === carModelData.length - 1;      }, false),      color: Cesium.Color.CORAL,      scale: 75,      scaleByDistance,      distanceDisplayCondition,    },  });}function changeCarPosition(position) {  cartesian3 = Cesium.Cartesian3.fromDegrees(    position.longitude,    position.latitude,    0.4  );}
岳阳文
2023-08-15

你之前的代码在循环建新的模型,试试只建一个模型,更新位置和方向:

function CarModel(position, angle) {  const headingPitchRoll = new Cesium.HeadingPitchRoll(    Cesium.Math.toRadians(110),    Cesium.Math.toRadians(0),    Cesium.Math.toRadians(0)  );  const scaleByDistance = new Cesium.NearFarScalar(200, 120, 1200, 0.6);  const distanceDisplayCondition = new Cesium.DistanceDisplayCondition(0, 10000);  const cartesian3 = Cesium.Cartesian3.fromDegrees(position.longitude, position.latitude, 0.4);  if (!carModelData) {    carModelData = viewer.entities.add({      position: cartesian3,      orientation: Cesium.Transforms.headingPitchRollQuaternion(cartesian3, headingPitchRoll),      model: {        uri: "http://127.0.0.1:5501/car/scene.gltf",        color: Cesium.Color.CORAL,        scale: 75,        scaleByDistance,        distanceDisplayCondition,      },    });  } else {    carModelData.position = cartesian3;    carModelData.orientation = Cesium.Transforms.headingPitchRollQuaternion(cartesian3, headingPitchRoll);  }}

只渲染最新的位置,看看这个:

function CarModel(positions, angle) {  const headingPitchRoll = new Cesium.HeadingPitchRoll(    Cesium.Math.toRadians(110),    Cesium.Math.toRadians(0),    Cesium.Math.toRadians(0)  );  const scaleByDistance = new Cesium.NearFarScalar(200, 120, 1200, 0.6);  const distanceDisplayCondition = new Cesium.DistanceDisplayCondition(0, 10000);  // 获取最新的位置  const latestPosition = positions[positions.length - 1];  const cartesian3 = Cesium.Cartesian3.fromDegrees(latestPosition.longitude, latestPosition.latitude, 0.4);  if (!carModelData) {    carModelData = viewer.entities.add({      position: cartesian3,      orientation: Cesium.Transforms.headingPitchRollQuaternion(cartesian3, headingPitchRoll),      model: {        uri: "http://127.0.0.1:5501/car/scene.gltf",        color: Cesium.Color.CORAL,        scale: 75,        scaleByDistance,        distanceDisplayCondition,      },    });  } else {    carModelData.position = cartesian3;    carModelData.orientation = Cesium.Transforms.headingPitchRollQuaternion(cartesian3, headingPitchRoll);  }}
 类似资料:
  • 流程: 问题: 求教各位朋友,这个情况如何解决? 代码: 结果 数组置空, setSessionList([]) 这一步没有什么作用 补充 需求就是点击左边不同的用户,右边显示与当前用户的会话数据列表 现在的问题是,我点击多个用户后,显示的是这多个用户所有的会话数据列表,而我只需要显示当前被点击的这个用户的会话数据列表 比如: 与A用户的会话数据是 [{id:1}, {id:2}] 当我依次点击A

  • 我正在使用LWJGL 2.8.5开发一个3D可视化应用程序。在阅读了项目主页上的第一个教程后,我还阅读了一本OpenGL书籍,进行了更深入的分析。我看到OpenGL中的典型过程是在init函数中绘制场景,然后简单地在一个循环中调用显示的更新。 但是,当我尝试使用LWJGL时,我在显示屏中得到了闪烁效果。消除闪烁的唯一方法是在显示更新周期中重绘场景。为什么会发生这种情况? 为了更好地解释我的问题,我

  • 6.1 渲染模板 一旦你拥有一个模版文件,你可以通过给一个map来给它传递数据。 map是一个变量及赋予的值的集合,模板使用它来得到变量的值,或者对于块标签求值。 它的渲染函数有一个可选的变量键值对map 通过 ctx.Render() 方法来渲染模板,例如: func (r *Render) Serve(ctx *faygo.Context) error { return ctx.Ren

  • 如前所述,我使用的是闪亮的仪表板。传单地图在放大时不呈现。代码是这样的。它在给定的lat,long上绘制标记。当放大时,它不工作。并且在放大时看起来是静态的,不进行渲染。需要尽快帮助。 server.r UI.R(只是一段很重要的代码)

  • 我有一个标题,我想显示一个图像在它的右边,当鼠标在标题上。 > 我正在将变量editMode的状态设置为true/false 然后我使用onMouseOver和onMouse事件有条件地呈现图像。 现在,当我悬停在标题上时,编辑模式设置为true,图像显示出来,当我将光标移出标题时,editMode设置为false,图像消失。 我正在维护一个变量editMode的状态,该状态被设置为true/fa

  • 我们当前的任务要求我们在openGL中使用较旧的固定管道方法。我们使用的是LWJGL 2.9.3。下面的代码显示一个三角形。问题是,它会疯狂地闪烁。显示器。swapBuffers()方法不会引发异常,并且无论是否包含它都没有任何区别。我根据这个问题创建了这个示例: gluPerspective、GluViewport、gluLookAt以及GL_投影和GL_MODELVIEW矩阵 编辑 还有一件事