PDAL中filters.divider过滤器对大点云文件进行分割

 

//pdal库将las文件分割为多个文件
void dividerLAS()
{
	using namespace pdal;
	using namespace pdal::Dimension;

	std::string in_filename = "F:\\pointCloud_data\\zhangjiang8\\pointcloud\\181013_030701-11-16-47-028.las";//中文路径可能报错
	std::string fileName = "d:/out_#.las";
	Options readerOps;
	readerOps.add("filename", in_filename);
	LasReader r;
	r.setOptions(readerOps);
	pdal::Options filterOps;
	//filterOps.add("type", "filters.divider");
	filterOps.add("capacity", 900000);    //最大容量90万个点
	//filterOps.add("count", 10);     //将view分成10份

	pdal::DividerFilter f;
	f.setInput(r);
	f.setOptions(filterOps);

	PointTable table;
	f.prepare(table);
	pdal::PointViewSet s = f.execute(table);

	Options xjOptions;
	xjOptions.add("filename", fileName);
	//double xoffset = 0.0, yoffset = 0.0, zoffset = 0.0;
	//xjOptions.add("offset_x", xoffset);
	//xjOptions.add("offset_y", yoffset);
	//xjOptions.add("offset_z", zoffset);
	//xjOptions.add("scale_x", 0.001);
	//xjOptions.add("scale_y", 0.001);
	//xjOptions.add("scale_z", 0.001);

	pdal::PointTable table1;
	table1.layout()->registerDim(Dimension::Id::X);
	BufferReader xjBufferReader;
	for (pdal::PointViewPtr v : s)
	{
		xjBufferReader.addView(v);
	}
	StageFactory factory;
	Stage *writer = factory.createStage("writers.las");
	writer->setInput(xjBufferReader);
	writer->setOptions(xjOptions);
	writer->prepare(table1);
	writer->execute(table1);
	
}

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值