当前位置:   article > 正文

点云可视化

点云可视化

目录

在视图界面操作及效果

CloudViewer 类

PCLVisualizer 类

         基础显示功能

按键事件

点选取事件

区域选取事件

显示区域分割


pcl_viewer 是 Point Cloud Library (PCL) 提供的一个用于可视化点云数据的工具。

在视图界面操作及效果

功能操作效果
帮助在界面中输入h,可以在控制台看到帮助信息
退出界面中输入q
放大缩小鼠标滚轮 或 Alt + [+/-]
平移Shift+鼠标拖拽
旋转Ctrl+鼠标拖拽360度旋转
保存截图j保存在.cpp文件所在路径
显示颜色尺寸u
显示刻度网格g
显示当前摄像机/窗口参数c
在透视/平行投影之间切换(默认=透视)o

CloudViewerPCLVisualizer 是 PCL 中两个不同的类,都用于创建和管理点云数据的可视化窗口。

CloudViewer 类

  CloudViewer 类是一种比较简单的点云可视化器,它提供了基本的点云显示功能。你可以使用 CloudViewer 创建一个点云可视化窗口,并将点云数据显示在窗口中。

例子一:

  1. #include <pcl/io/pcd_io.h>
  2. #include <pcl/point_types.h>
  3. // 包含相关头文件
  4. #include <pcl/visualization/cloud_viewer.h>
  5. typedef pcl::PointXYZ PointT;
  6. int main()
  7. {
  8. // 读取点云
  9. pcl::PointCloud<PointT>::Ptr cloud(new pcl::PointCloud<PointT>);
  10. pcl::io::loadPCDFile("../input_cloud/rabbit.pcd", *cloud);
  11. pcl::visualization::CloudViewer viewer("simple cloud viewer");
  12. viewer.showCloud(cloud);
  13. while (!viewer.wasStopped())
  14. {
  15. // todo::
  16. }
  17. system("pause");
  18. return 0;
  19. }

例子二:

  1. #include <pcl/visualization/cloud_viewer.h>
  2. #include <iostream>
  3. #include <pcl/io/io.h>
  4. #include <pcl/io/pcd_io.h>
  5. void viewerOneOff(pcl::visualization::PCLVisualizer& viewer) {
  6. // 设置背景色为紫色色
  7. viewer.setBackgroundColor(0.5843, 0.6, 0.8392);
  8. pcl::PointXYZ o;
  9. o.x = 1.0;
  10. o.y = 1.0;
  11. o.z = 0;
  12. // 添加一个圆心为o,半径为0.25m的球体
  13. viewer.addSphere(o, 0.25, "sphere", 0);
  14. viewer.setShapeRenderingProperties(pcl::visualization::PCL_VISUALIZER_COLOR, 1.0, 0.0, 0.0, "sphere");
  15. std::cout << "i only run once" << std::endl;
  16. }
  17. int main() {
  18. pcl::PointCloud<pcl::PointXYZRGBA>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZRGBA>);
  19. pcl::io::loadPCDFile("../data/pcl_logo.pcd", *cloud);
  20. pcl::visualization::CloudViewer viewer("Cloud Viewer");
  21. //这里会一直阻塞直到点云被渲染
  22. viewer.showCloud(cloud);
  23. // 只会调用一次 (非必须)
  24. viewer.runOnVisualizationThreadOnce(viewerOneOff);
  25. while (!viewer.wasStopped()) {
  26. }
  27. return 0;
  28. }
  1. #include <pcl/visualization/cloud_viewer.h>
  2. #include <iostream>
  3. #include <pcl/io/io.h>
  4. #include <pcl/io/pcd_io.h>
  5. void viewerPsycho(pcl::visualization::PCLVisualizer& viewer) {
  6. static unsigned count = 0;
  7. std::stringstream ss;
  8. ss << "Once per viewer loop: " << count++;
  9. // 每次刷新时,移除text,添加新的text
  10. viewer.removeShape("text1", 0);
  11. viewer.addText(ss.str(), 200, 300, "text1", 0);
  12. }
  13. int main() {
  14. pcl::PointCloud<pcl::PointXYZRGBA>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZRGBA>);
  15. pcl::io::loadPCDFile("../data/pcl_logo.pcd", *cloud);
  16. pcl::visualization::CloudViewer viewer("Cloud Viewer");
  17. //这里会一直阻塞直到点云被渲染
  18. viewer.showCloud(cloud);
  19. // 每次可视化迭代都会调用一次(频繁调用) (非必须)
  20. //viewer.runOnVisualizationThread(viewerPsycho);
  21. while (!viewer.wasStopped()) {
  22. }
  23. return 0;
  24. }

效果图如下: 

viewer.runOnVisualizationThreadOnce(viewerOneOff);viewer.runOnVisualizationThread(viewerPsycho);

PCLVisualizer 类

  PCLVisualizer 类是一个更为强大和灵活的点云可视化器,具有更多的可定制性和扩展性。你可以使用 PCLVisualizer 创建一个可视化窗口,并通过其提供的方法添加、删除和修改点云、文本、几何图形等对象,以及设置视角、光照和渲染属性等。

基础显示功能

例子一:

  1. #include <pcl/io/pcd_io.h>
  2. #include <pcl/visualization/pcl_visualizer.h>
  3. int main(int argc, char** argv) {
  4. pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);
  5. pcl::io::loadPCDFile("../data/bunny.pcd", *cloud);
  6. pcl::PointCloud<pcl::PointXYZRGB>::Ptr cloud_milk(new pcl::PointCloud<pcl::PointXYZRGB>);
  7. pcl::io::loadPCDFile("../data/milk_color.pcd", *cloud_milk);
  8. // 创建PCLVisualizer
  9. boost::shared_ptr<pcl::visualization::PCLVisualizer> viewer(new pcl::visualization::PCLVisualizer("3D Viewer"));
  10. // 设置背景色为浅黄色(非必须)
  11. viewer->setBackgroundColor(0.9647, 0.9412, 0.8392, 0);
  12. // 添加一个普通点云的颜色处理器 (可以设置指定颜色,也可以去掉single_color参数不设置)
  13. pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> single_color(cloud, 192, 127, 220);
  14. viewer->addPointCloud<pcl::PointXYZ>(cloud, single_color, "sample cloud");
  15. viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE, 2, "sample cloud");
  16. // 再添加一个彩色点云及配置
  17. pcl::visualization::PointCloudColorHandlerRGBField<pcl::PointXYZRGB> rgb(cloud_milk);
  18. viewer->addPointCloud<pcl::PointXYZRGB>(cloud_milk, rgb, "sample cloud milk");
  19. viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE, 3, "sample cloud milk");
  20. // 添加一个0.5倍缩放的坐标系(非必须)
  21. viewer->addCoordinateSystem(0.5);
  22. // 直到窗口关闭才结束循环
  23. while (!viewer->wasStopped()) {
  24. // 每次循环调用内部的重绘函数
  25. viewer->spinOnce();
  26. }
  27. return 0;
  28. }

 

ps:setBackgroundColor()参数范围0.0~1.0;PointCloudColorHandlerCustom()参数范围0~255.

 例子二:显示点云、网格、设置颜色、连线

  1. #include <pcl/io/pcd_io.h>
  2. #include <pcl/io/ply_io.h>
  3. #include <pcl/point_types.h>
  4. // 包含相关头文件
  5. #include <pcl/visualization/pcl_visualizer.h>
  6. #include <boost/date_time/posix_time/posix_time.hpp>
  7. #include <boost/thread/thread.hpp>
  8. typedef pcl::PointXYZ PointT;
  9. int main()
  10. {
  11. // 读取点云
  12. pcl::PointCloud<PointT>::Ptr cloud1(new pcl::PointCloud<PointT>);
  13. pcl::io::loadPCDFile("../input_cloud/DKdata.pcd", *cloud1);
  14. pcl::PointCloud<PointT>::Ptr cloud2(new pcl::PointCloud<PointT>);
  15. pcl::io::loadPCDFile("../input_cloud/rabbit.pcd", *cloud2);
  16. // 定义对象
  17. pcl::visualization::PCLVisualizer viewer;
  18. //设置背景颜色,默认黑色
  19. viewer.setBackgroundColor(100, 100, 100); // rgb
  20. // --- 显示点云数据 ----
  21. // "cloud1" 为显示id,默认cloud,显示多个点云时用默认会报警告。
  22. pcl::visualization::PointCloudColorHandlerCustom<PointT> green(cloud1, 0, 255, 0);
  23. viewer.addPointCloud(cloud1, green,"cloud1");
  24. pcl::visualization::PointCloudColorHandlerCustom<PointT> red(cloud2, 0, 0, 255); // rgb
  25. // 将点云设置颜色,默认白色
  26. viewer.addPointCloud(cloud2, red, "cloud2");
  27. // 将两个点连线
  28. PointT temp1 = cloud1->points[0];
  29. PointT temp2 = cloud1->points[100];
  30. //viewer.addLine(temp1, temp2, "line0");
  31. // 同样可以设置线的颜色,
  32. viewer.addLine(temp1, temp2, 255, 0, 0, "line0");
  33. // 开始显示2种方法,任选其一
  34. // 2. 非阻塞式
  35. while (!viewer.wasStopped())
  36. {
  37. viewer.spinOnce(100);
  38. boost::this_thread::sleep(boost::posix_time::microseconds(100000));
  39. // 可添加其他操作
  40. }
  41. // 1. 阻塞式
  42. //viewer.spin();
  43. system("pause");
  44. return 0;
  45. }

  按键事件

激活点云显示窗口,键盘按下a,删除点云,再按a,显示点云

  1. #include <pcl/io/pcd_io.h>
  2. #include <pcl/visualization/pcl_visualizer.h>
  3. // 回掉函数所用数据结构
  4. struct callback_args {
  5. bool* isShow;
  6. pcl::PointCloud<pcl::PointXYZ>::Ptr orgin_points;
  7. pcl::visualization::PCLVisualizer::Ptr viewerPtr;
  8. };
  9. // 按键事件回掉函数
  10. void kb_callback(const pcl::visualization::KeyboardEvent& event, void* args)
  11. {
  12. if (event.keyDown() && event.getKeyCode() == 'a')
  13. {
  14. std::cout << "a has pressed" << std::endl;
  15. struct callback_args* data = (struct callback_args*)args;
  16. if (*(data->isShow))
  17. {
  18. data->viewerPtr->removePointCloud("cloud");
  19. *(data->isShow) = false;
  20. std::cout << "remove point cloud" << std::endl;
  21. }
  22. else {
  23. pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> IndianRed2(data->orgin_points, 238, 217 , 85);
  24. data->viewerPtr->addPointCloud(data->orgin_points, IndianRed2, "cloud");
  25. *(data->isShow) = true;
  26. std::cout << "add point cloud" << std::endl;
  27. }
  28. }
  29. }
  30. int main(int argc, char** argv)
  31. {
  32. pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);
  33. pcl::io::loadPCDFile("../input_cloud/DKdata2.pcd", *cloud);
  34. pcl::console::print_highlight("load cloud !\n");
  35. // 定义对象
  36. pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer);
  37. pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> IndianRed2(cloud, 238, 99, 99);
  38. viewer->addPointCloud(cloud, IndianRed2, "cloud");
  39. // 初始化参数
  40. bool isShow = true;
  41. struct callback_args kb_args;
  42. kb_args.isShow = &isShow;
  43. kb_args.orgin_points = cloud;
  44. kb_args.viewerPtr = viewer;
  45. // 设置回调函数
  46. viewer->registerKeyboardCallback(kb_callback, (void*)&kb_args);
  47. viewer->spin();
  48. return 0;
  49. }

 点选取事件

按住Shift键同时按下鼠标左键,点击可视化窗口;想退出时激活控制台窗口,键盘输入Q

  1. #include <pcl/io/pcd_io.h>
  2. #include <pcl/point_types.h>
  3. #include <pcl/visualization/pcl_visualizer.h>
  4. struct callback_args {
  5. // structure used to pass arguments to the callback function
  6. int a; //为了对齐
  7. pcl::PointCloud<pcl::PointXYZ>::Ptr clicked_points_3d;
  8. pcl::visualization::PCLVisualizer::Ptr viewerPtr;
  9. };
  10. void pp_callback(const pcl::visualization::PointPickingEvent& event, void* args)
  11. {
  12. struct callback_args* data = (struct callback_args*)args;
  13. if (event.getPointIndex() == -1)
  14. return;
  15. int index = event.getPointIndex();
  16. std::cout << "index: " << index << std::endl;
  17. pcl::PointXYZ current_point;
  18. event.getPoint(current_point.x, current_point.y, current_point.z);
  19. // 检查容器内存空间是否足够,如果需要则扩充
  20. if (data->clicked_points_3d->size() >= data->clicked_points_3d->points.capacity())
  21. {
  22. data->clicked_points_3d->reserve(data->clicked_points_3d->size() + 100);
  23. }
  24. data->clicked_points_3d->points.push_back(current_point);
  25. // Draw clicked points in red:
  26. pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> purple(data->clicked_points_3d, 186, 180, 246);
  27. data->viewerPtr->removePointCloud("clicked_points");
  28. data->viewerPtr->addPointCloud(data->clicked_points_3d, purple, "clicked_points");
  29. data->viewerPtr->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE, 10, "clicked_points");
  30. std::cout << current_point.x << " " << current_point.y << " " << current_point.z << std::endl;
  31. }
  32. int main(int argc, char** argv)
  33. {
  34. pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);
  35. pcl::io::loadPCDFile("../input_cloud/rabbit.pcd", *cloud);
  36. pcl::console::print_highlight("load cloud !\n");
  37. //pcl::visualization::PCLVisualizer viewer;
  38. pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer);
  39. pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> orange(cloud, 252, 196, 143);
  40. viewer->addPointCloud(cloud, orange, "cloud");
  41. // Add point picking callback to viewer:
  42. pcl::PointCloud<pcl::PointXYZ>::Ptr clicked_points_3d(new pcl::PointCloud<pcl::PointXYZ>);
  43. struct callback_args cb_args;
  44. cb_args.clicked_points_3d = cloud;
  45. cb_args.viewerPtr = viewer;
  46. viewer->registerPointPickingCallback(pp_callback, (void*)&cb_args);
  47. pcl::console::print_highlight("Shift+click on three floor points, then press 'Q'...\n");
  48. // Spin until 'Q' is pressed:
  49. viewer->spin();
  50. system("pause");
  51. return 0;
  52. }

区域选取事件

  1. /*在视图窗口页面按下x键,鼠标左键按钮拖动选择,按下q键关闭视图窗口;在控制台窗口按任意键即可关闭视图窗口*/
  2. #include <pcl/io/pcd_io.h>
  3. #include <pcl/point_types.h>
  4. #include <pcl/visualization/pcl_visualizer.h>
  5. struct callback_args {
  6. // structure used to pass arguments to the callback function
  7. pcl::PointCloud<pcl::PointXYZ>::Ptr orgin_points;
  8. pcl::PointCloud<pcl::PointXYZ>::Ptr chosed_points_3d;
  9. pcl::visualization::PCLVisualizer::Ptr viewerPtr;
  10. };
  11. void ap_callback(const pcl::visualization::AreaPickingEvent& event, void* args)
  12. {
  13. struct callback_args* data = (struct callback_args*)args;
  14. std::vector<int> indiecs;
  15. if (!event.getPointsIndices(indiecs))
  16. return;
  17. for (int i = 0; i < indiecs.size(); ++i)
  18. {
  19. data->chosed_points_3d->push_back(data->orgin_points->points[indiecs[i]]);
  20. }
  21. // Draw clicked points in red:
  22. pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> red(data->chosed_points_3d, 255, 0, 0);
  23. data->viewerPtr->removePointCloud("chosed_points");
  24. data->viewerPtr->addPointCloud(data->chosed_points_3d, red, "chosed_points");
  25. data->viewerPtr->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE, 5, "chosed_points");
  26. std::cout << "selected " << indiecs.size() << " points , now sum is " << data->chosed_points_3d->size() << std::endl;
  27. }
  28. int main(int argc, char** argv)
  29. {
  30. pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);
  31. pcl::io::loadPCDFile("../input_cloud/rabbit.pcd", *cloud);
  32. pcl::console::print_highlight("load cloud !\n");
  33. pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer);
  34. pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> green(cloud, 0, 255, 0);
  35. viewer->addPointCloud(cloud, green, "cloud");
  36. // Add point picking callback to viewer:
  37. struct callback_args cb_args;
  38. cb_args.orgin_points = cloud;
  39. pcl::PointCloud<pcl::PointXYZ>::Ptr chosed_points_3d(new pcl::PointCloud<pcl::PointXYZ>);
  40. cb_args.chosed_points_3d = chosed_points_3d;
  41. cb_args.viewerPtr = viewer;
  42. viewer->registerAreaPickingCallback(ap_callback, (void*)&cb_args);
  43. pcl::console::print_highlight("press x enter slected model, then press 'qQ'...\n");
  44. //viewer->spin(); //使用这句代码,选取区域后不会有实时更新的效果
  45. while (!viewer->wasStopped())
  46. {
  47. viewer->spinOnce(100); // 等待 100 毫秒后更新可视化窗口
  48. }
  49. system("pause");
  50. return 0;
  51. }

 

显示区域分割

pcl可以将显示区域分割,从(xmin,ymin)到(xmax,ymax)一个矩形区域,范围是(0,1)。左下角(0,0),右上角(1,1)

  1. #include <pcl/io/pcd_io.h>
  2. #include <pcl/point_types.h>
  3. // 包含相关头文件
  4. #include <pcl/visualization/pcl_visualizer.h>
  5. typedef pcl::PointXYZ PointT;
  6. int main()
  7. {
  8. // 读取点云
  9. pcl::PointCloud<PointT>::Ptr cloud(new pcl::PointCloud<PointT>);
  10. pcl::io::loadPCDFile("../input_cloud/rabbit.pcd", *cloud);
  11. // 定义对象
  12. pcl::visualization::PCLVisualizer viewer;
  13. int v1(1); // viewport
  14. viewer.createViewPort(0.0, 0.0, 0.5, 1.0, v1);
  15. viewer.setBackgroundColor(0,255,0, v1);
  16. viewer.addPointCloud(cloud, "cloud1", v1);;
  17. int v2(2);// viewport
  18. viewer.createViewPort(0.5, 0.0, 1.0, 1.0, v1);
  19. viewer.setBackgroundColor(0, 0, 255, v2);
  20. viewer.addPointCloud(cloud, "cloud2", v2);;
  21. viewer.spin();
  22. system("pause");
  23. return 0;
  24. }

ps:背景颜色换成其他的就不能看到点云了,真不知道为什么

pcl_viewer工具使用

pointCloudLibrary点云库在windows下使用pcl_viewer工具

(1)首先在点云库安装目录下找到pcl_viewer.exe,具体根据自己的安装目录确定

(2)使用cmd命令行打开

   cd 到pcl_viewer.exe 路径,敲入命令:

pcl_viewer.exe F:\DarkHorse\data\ism_train.pcd

   (3)  pcl_viewer命令行参数说明

a.   使用  -bc -fc 改变pcl_viewer前景色,背景色

pcl_viewer.exe F:\DarkHorse\data\lamppost.pcd -bc 172,226,218 -fc 255,0,255

 b  加入前景色(-fc)、背景色(-bc)、不透明度(-opaque)、坐标轴(-ax),坐标轴沿X轴平移20(-ax_pos 20,0,0)

pcl_viewer.exe F:\DarkHorse\data\lamppost.pcd -bc 212,224,218 -fc 255,0,255 -ax 3 -opaque 0.8  -ax_pos -20,0,0

参考:pointCloudLibrary点云库pcl_viewer工具使用

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号