使用std::vector优化点云动画显示一例

1. 准备

使用std::vector应该知道几点:

(1)内存连续的容器,有点像数组

(2)与std::list相比,插入和删除元素比较慢- 因为数据迁移

(3)添加元素可能会引发内存分配和数据迁移。

2. 问题

AnyCAD::API::PointCloudNode使用FloatList  及std::vector<float>来存储一些列的点[x0, y0, z0, x1, y1, z1, .....]:

void  SetPoints (const FloatList &buffer)

若想要显示n个点,需要3n的长度:

为了在空间中模拟某个物体的运动轨迹,即一系列的点,如何才能高效的实现动态绘制呢?

3. 方案

最基本的办法:

定义的变量:

PointCloudNode m_PointCoud;
std::_vector<float> m_Points;

每次调用push_back添加点:

void onAddPoint(x, y, z)
{
     m_Points.push(x);
     m_Points.push(y);
     m_Points.push(z);
     m_PointCloud.SetPoints(m_Points);

     render();
}

“优化1”:为了减少显示的点太多引起内存问题和效率问题,可以限定显示的点的个数

int MAX_POINT3_COUNT = MAX_POINT_COUNT * 3;

void onAddPointV1(x, y, z)
{
   if(m_Points.size() > MAX_POINT3_COUNT)
   {
        m_Points.erase(m_Points.begin());
        m_Points.erase(m_Points.begin());
        m_Points.erase(m_Points.begin());
    }
     m_Points.push(x);
     m_Points.push(y);
     m_Points.push(z);
     m_PointCloud.SetPoints(m_Points);

     render();
}

onAddPointV1引入了什么问题?

优化2:避免每次vector都重新分配内存,指定vector的初始内存大小

m_Points.reserve(MAX_POINT3_COUNT);

优化3:避免由于删除头元素引擎的数据迁移

新加入的点放在队尾还是队头,对于显示而言,结果都是一样一样的。所以可以覆盖”过期的"的点。

int m_TotalCount = 0;

void onAddPointV3(x, y, z)
{
      ++m_TotalCount;
      if(m_TotalCount <= MAX_POINT_COUNT)
      {
               m_Points.push_back(x);
               m_Points.push_back(y);
               m_Points.push_back(z);
      }
      else
      {
           int pos = (m_TotalCount % 100 - 1) * 3;
           m_Points[pos] = x;
           m_Points[pos+1] = y;
           m_Points[pos+2] = z;
      }

      m_PointCloud.SetPoints(m_Points);

      render();
}

4 总结

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-12-12 05:40:47

使用std::vector优化点云动画显示一例的相关文章

显示层封装及实现与优化(无动画+css3动画+js动画)

showhide.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>showhide</title> <link rel="stylesheet" href="../css/base.css"> <style> body{ width

C++ error C2440: “类型转换” : 无法从“std::vector::iterator”转换为“

原文地址:http://blog.csdn.net/onlyou930/article/details/5602654 圆环套圆环之迭代器 话说这一日是风平浪静,万里乌云,俺的心情好的没得说,收到命令清理A区(写部分代码,其中有在VC6下己完成的代码要移植到VC7下),一路上很轻松,用‘饭得标’的话来说就是‘卡卡’地!在快完成时出现错误. error C2440: “类型转换” : 无法从“std::vector<_Ty>::iterator”转换为“PPkgHead”with[_Ty=BYT

EVC编程点滴-GIF动画显示类

此功能在我这个项目中,主要是显示让用户等待的提示.如开机过程.待机界面调用一个系统应用的过程.还有就是操作大尺寸图片的过程. 刚开始是用自定义的一个窗体来提示用户的,功能也可以实现,但美观度不够.所以才花了一定时间,对网上这个类进行研究.最终成功应用于项目中. 这个类的实现,主要是参考网上一个名为CGif89a类的实现. 此类在EVC4工程中可以正常使用. 索引: 1) GIF显示类头文件 2) GIF显示类的实现 3) 调用CGIFShow类示例 (1) 定义全局变量 (2) 在窗体的WM_C

error LNK2005: “public: class std::vector&lt;class std::vector&lt;class std::vector&lt;float&gt;”

VS2010:error LNK2005: "public: class std::vector<class std::vector<class std::vector<class std::vector<float,class std::allocator<float> >,class std::allocator<class std::vector<float,class std::allocator<float> 如: Re

C++ vector中实际删除元素使用的是容器vecrot中std::vector::erase()方法

C++ vector中实际删除元素使用的是容器vecrot中std::vector::erase()方法. C++ 中std::remove()并不删除元素,因为容器的size()没有变化,只是元素的替换. 1.std::vector::erase() 函数原型:iterator erase (iterator position); //删除指定元素 iterator erase (iterator first, iterator last); //删除指定范围内的元素 返回值:指向删除元素(或

C++ std::vector 三种遍历方式的效率比较

#include <iostream> #include <vector> #include <stdint.h> #include <ctime> int main() { const uint32_t loop = 1000000; std::vector<int32_t> vec; clock_t timeStart = 0; for (uint32_t i = 0; i < loop; ++i) { vec.push_back(i)

Js_动画显示背景图片

jAni是一个可以动画显示背景图片的jQuery插件.这个插件基本上是GIF动画的一个替代品,但是他有他的好处.所有浏览器都支持GIF形式的动画格式,而且也不需要额外的javaScript代码和标记.但是不好的一点是,GIF格式的图片只有256色.而且你不能控制图片的显示.这个插件通过载入垂直的GIF帧,然后改变容器的background-postion来显示动画,这样你就可以自由控制了. 特色 轻量级的脚本 很容易使用 可以通过CSS完全定制 所有浏览器都支持 如何使用 1.下载脚本,并包含j

C++ 中的std::vector介绍(转)

vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据. 为了可以使用vector,必须在你的头文件中包含下面的代码: #include <vector> vector属于std命名域的,因此需要通过命名限定,如下完成你的代码: using std::vector; vector<int

实战c++中的string系列--std:vector&lt;char&gt; 和std:string相互转换(vector to stringstream)

有时候也会遇到std:vector与转std:string 相互转换的情况. 首先看一下vector<char>如何转string: std::vector<char> *data = response->getResponseData(); std::string res; //方法一 for (int i = 0;i<data->size();++i) { res+=(*data)[i]; } res+='\0'; std:cout << res;