当前位置: 首页 > news >正文

万网个人网站有什么推广产品的渠道

万网个人网站,有什么推广产品的渠道,做网站需要字体授权,谁有日韩跟老外做的网站CGAL 从DSM到DTM-建筑物区域提取 生成的DSM被用作DTM计算的基础,即地面表示为过滤掉非地面点后的另一个TIN。主要是去除一些建筑物和植被非地形点。 建筑物立面及连通区域提取 建筑物立面的特征是三角形面片的高度变化剧烈。 通过遍历每一个三角面片,…

CGAL 从DSM到DTM-建筑物区域提取

生成的DSM被用作DTM计算的基础,即地面表示为过滤掉非地面点后的另一个TIN。主要是去除一些建筑物和植被非地形点。

建筑物立面及连通区域提取

建筑物立面的特征是三角形面片的高度变化剧烈。
通过遍历每一个三角面片,计算顶点之间最大的高差face_height,与事先设置的阈值spacing比较,大于阈值或包含无限远点infinite_vertex标记为建筑物立面。

除去建筑物立面,对剩下的三角面片使用洪水算法确定连通区域,并标记对应的区域id,取值范围:[0,component_size.size()]

代码

#include<iostream>#include<CGAL/Surface_mesh.h>
#include<CGAL/Surface_mesh/IO/PLY.h>#include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
#include <CGAL/Projection_traits_xy_3.h>
#include <CGAL/Delaunay_triangulation_2.h>
#include <CGAL/Triangulation_vertex_base_with_info_2.h>
#include <CGAL/Triangulation_face_base_with_info_2.h>#include <CGAL/boost/graph/graph_traits_Delaunay_triangulation_2.h>
#include <CGAL/boost/graph/copy_face_graph.h>#include <CGAL/compute_average_spacing.h>using Kernel = CGAL::Exact_predicates_inexact_constructions_kernel;using Projection_traits = CGAL::Projection_traits_xy_3<Kernel>;using Point_3 = Kernel::Point_3;
using Mesh = CGAL::Surface_mesh<Point_3>;using Concurrency_tag = CGAL::Sequential_tag;using Vbi = CGAL::Triangulation_vertex_base_with_info_2 <Mesh::Vertex_index, Projection_traits>;
using Fbi = CGAL::Triangulation_face_base_with_info_2<int, Projection_traits>;
using TDS = CGAL::Triangulation_data_structure_2<Vbi, Fbi>;
using TIN_with_info = CGAL::Delaunay_triangulation_2<Projection_traits, TDS>;int main() {Mesh mesh;CGAL::IO::read_PLY("./data/dsm.ply", mesh);auto idx_to_point_with_info= [&](const Mesh::Vertex_index& idx) -> std::pair<Point_3, Mesh::Vertex_index>{return std::make_pair ( mesh.point(idx), idx);};TIN_with_info tin_with_info(boost::make_transform_iterator (mesh.vertices().begin(), idx_to_point_with_info),boost::make_transform_iterator (mesh.vertices().end(), idx_to_point_with_info));double spacing = CGAL::compute_average_spacing<Concurrency_tag>(mesh.points(), 6);spacing *= 2;auto face_height= [&](const TIN_with_info::Face_handle fh) -> double{double out = 0.;for (int i = 0; i < 3; ++ i)out = (std::max) (out, CGAL::abs(fh->vertex(i)->point().z() - fh->vertex((i+1)%3)->point().z()));return out;};// Initialize faces info 初始化三角面附件信息(int类型)for (TIN_with_info::Face_handle fh : tin_with_info.all_face_handles())if (tin_with_info.is_infinite(fh) || face_height(fh) > spacing) // Filtered faces are given info() = -2fh->info() = -2;else // Pending faces are given info() = -1;fh->info() = -1;// Flooding algorithmstd::vector<int> component_size;for (TIN_with_info::Face_handle fh : tin_with_info.finite_face_handles()){if (fh->info() != -1)continue;std::queue<TIN_with_info::Face_handle> todo;todo.push(fh);int size = 0;while (!todo.empty()){TIN_with_info::Face_handle current = todo.front();todo.pop();if (current->info() != -1)continue;current->info() = int(component_size.size());++ size;for (int i = 0; i < 3; ++ i)todo.push (current->neighbor(i));}component_size.push_back (size);}std::cerr << component_size.size() << " connected component(s) found" << std::endl;Mesh tin_colored_mesh;//Mesh::Property_map<Mesh::Face_index, CGAL::IO::Color>color_map = tin_colored_mesh.add_property_map<Mesh::Face_index, CGAL::IO::Color>("f:color").first;CGAL::copy_face_graph (tin_with_info, tin_colored_mesh,CGAL::parameters::face_to_face_output_iterator(boost::make_function_output_iterator([&](const std::pair<TIN_with_info::Face_handle, Mesh::Face_index>& ff){// 灰色标记建筑物立面及待处理的其他非地面点if (ff.first->info() < 0){color_map[ff.second] = CGAL::IO::Color(128, 128, 128);// put(color_map, ff.second, CGAL::IO::Color(128, 128, 128));}else{// 其他标记随机颜色CGAL::Random r (ff.first->info());color_map[ff.second] = CGAL::IO::Color (r.get_int(64, 192),r.get_int(64, 192),r.get_int(64, 192));/*put(color_map, ff.second, CGAL::IO::Color(r.get_int(64, 192),r.get_int(64, 192),r.get_int(64, 192)));*/}})));std::ofstream tin_colored_ofile ("colored_tin.ply", std::ios_base::binary);CGAL::IO::set_binary_mode (tin_colored_ofile);CGAL::IO::write_PLY (tin_colored_ofile, tin_colored_mesh);tin_colored_ofile.close();return 0;
}

如下图所示,灰色标记为建筑物立面,其他联通区域标记随机颜色:

coloredTIN

构建编译运行

cmake -B build -S . -DCMAKE_TOOLCHAIN_FILE=D:\vcpkg\scripts\buildsystems\vcpkg.cmake
cmake --build build --config Debug
.\build\Debug\coloredTIN.exe

参考

  1. https://doc.cgal.org/latest/Manual/tuto_gis.html
http://www.ds6.com.cn/news/48265.html

相关文章:

  • 如何做购物网站的教程详细的营销推广方案
  • wordpress 额外css专业搜索引擎seo服务商
  • 如何设计培训课程网页搜索优化软件
  • 合理规划网站结构seo关键词优化推广外包
  • 福永自适应网站建网站搭建流程
  • 用bootstrap做的外国网站seo舆情优化
  • 免费网站教程长春网站制作系统
  • 做网站充值微信必须是企业网络推广员是干嘛的
  • 深圳建设局网站查询搜索广告优化
  • 谁做的怀来吧网站微商怎么引流被别人加
  • 真正永久免费建站镇江搜索优化技巧
  • 苏州园区一站式服务中心广州seo推广营销
  • 计算机做网站难吗最新新闻热点事件
  • c#购物网站开发流程哪个平台可以免费推广
  • 公司网站公司新闻潍坊今日头条新闻
  • 网站锚文本的内链建设上海推广外包
  • 成都房地产网站开发品牌营销推广要怎么做
  • 做推广网站的文章学校网站建设哪家好
  • 响应式网站建设服务器长尾关键词挖掘精灵官网
  • 免费网站生成无锡百度推广代理商
  • 个人响应式网站软文如何推广
  • 模板网站哪家靠谱安徽seo人员
  • discuz 网站风格3小时百度收录新站方法
  • 成都网站优化排名推广湖北网站设计
  • 电子商务网站开发系统郑州seo方案
  • 常用网站开发技术项目网站
  • 对做网站有什么建议东莞网站制作公司联系方式
  • 一个电商网站开发要多久交换免费连接
  • 深圳营销网站建设品牌设计公司
  • 怎么原创视频网站网站seo重庆