Skip to content
  • 首页
  • 留言
  • 关于

Share the joys of programming and technology

去除重叠的闭合区域

去除重叠的闭合区域

2021年1月18日 liyanliang Comments 0 Comment
阅读次数: 224

题目描述

在图形开发过程中,需要求最小闭合区域,当获得了所有的闭合区域后,有一部分区域是重叠的,现设计算法将重叠的区域删除。(此算法类似于 删除无序数组中重复的元素)

一、去除重叠的图形

//去除重叠的图形
std::vector> removeOverlapArea(vector> ClosedArea)
{
//> 表示一个闭合区域,有多条线段围成
//vector> 表示闭合区域的集合
    unsigned int nSize = ClosedArea.size();
    if (nSize < 2) //只有一個閉合區域
    {
        return ClosedArea;
    }
​
//去除重叠的区域
size_t n = ClosedArea.size();
size_t j = 0;
​
for (size_t i=0; i < n; i++)
{
    for(size_t j=0;j<i;j++)
    {
        //if(arr[i]arr[j])
        if(IsOverlap(ClosedArea[i],ClosedArea[j]))
        {
            n--;
            for (size_t k=i; k<n; k++)
            {
                ClosedArea[k]=ClosedArea[k+1];
            }
            i--;    
        }
    }
}
​
vector<vector<CLine>>::iterator it1,it2;
​
it1 = ClosedArea.begin() + n;
it2 = ClosedArea.end();
​
ClosedArea.erase(it1,it2);
​
return ClosedArea;
​
}

二、判断是否是重合的图形

//判断是否是重合的图形
bool IsOverlap(vector AreaLeft,vector AreaRight) 
{
    for (unsigned int i = 0;i < AreaLeft.size(); i++)
    {
        CLine m_lineLeft = AreaLeft[i];
        bool bEqualLine = false;
        for (unsigned int j = 0;j < AreaRight.size();j++)
        {
            if (m_lineLeft.isEqual(AreaRight[j]))
            {
                bEqualLine = true;
            }
        }
        if (bEqualLine  false)
        {
            return false; //只要有一条线段不相同,必然不重合
        }
    }
    return true;
}

相关文章

  • 算法:寻找异常数字算法:寻找异常数字
  • 如何调试Revit二次开发代码-教学视频(解决无法调试问题)如何调试Revit二次开发代码-教学视频(解决无法调试问题)
  • OpenGL-法线贴图(Normal Mapping)OpenGL-法线贴图(Normal Mapping)
  • 3dTiles数据解析3dTiles数据解析
  • OpenGL-卡通着色(Cartoon)OpenGL-卡通着色(Cartoon)
  • Midas XD-选筋助手开发Midas XD-选筋助手开发

计算几何
计算几何

Post navigation

PREVIOUS
两跨连续梁影响线绘制-附源码
NEXT
判断一个点是否在闭合区域内

发表回复 取消回复

您的邮箱地址不会被公开。 必填项已用 * 标注

近期文章

  • ANR崩溃日志查看方法
  • 通过数学方法来计算short类型的变量w的低八位x和高八位
  • 3dTiles数据解析
  • Games101和Games202脑图汇总
  • LearnOpenGL脑图汇总
  • IBL计算总结
  • C++实现一个简单的语言解释器
  • OpenGL-法线贴图(Normal Mapping)
  • OpenGL-卡通着色(Cartoon)
  • OpenGL几何着色器实现贝塞尔曲线
  • WinDbg检查内存泄漏
  • OpenGL雾化效果实现-每像素雾化
  • OpenGL实现billboard效果(CPU)
  • 算法:寻找异常数字
  • OpenGL 几何着色器的应用
  • Midas XD-构件详图开发
  • Midas XD-选筋助手开发
  • Civil Designer开发-检测规范自动生成控制截面
  • Civil Designer开发-公路桥梁承载能力检算评定
  • Midas W-满堂支架快速建模助手开发

全站热点

  • C++编写的情人节小程序 (2,080)
  • 提取最小封闭区域 (1,693)
  • Modern OpenGL绘制圆柱体 (1,606)
  • OpenGL开发环境搭建-GLFW与GLAD配置 超详细 (1,459)
  • 截面特性计算程序-附源码 (1,288)
  • OpenGL绘制旋转立方体 (1,104)
  • 判断一个点是否在闭合区域内 (1,032)
  • WordPress分页插件 – WP-PageNavi的使用(替换现有脚本) (948)
  • OpenGL实现billboard效果(CPU) (864)
  • Midas W-满堂支架快速建模助手开发 (832)
  • 从DLL中动态加载一个函数:LoadLibrary和GetProcAddress的使用 (746)
  • Midas XD [错误] 右侧挡土墙的最下端深度必须小于地基的最下端深度 (708)
  • 两跨连续梁影响线绘制-附源码 (685)
  • 土木想往土木软件开发方向发展,应该如何准备 (679)
  • OpenGL几何着色器实现贝塞尔曲线 (663)
  • 通过Spy++抓取窗口以查询对话框id (612)
  • 使用ODA数据库出现 “ODA_ASSUME”: 找不到标识符的错误 (547)
  • #pragma message 编译时提示信息 (527)
  • OpenGL雾化效果实现-每像素雾化 (507)
  • midas XD2020的开发 (474)

分类

  • C# (3)
  • C++ (19)
  • GIS (1)
  • MFC (3)
  • ObjectARX (2)
  • OpenGL (11)
  • Revit开发 (1)
  • 学习笔记 (2)
  • 岩土 (2)
  • 算法 (1)
  • 结构设计 (7)
  • 职场生涯 (1)
  • 计算几何 (3)

归档

  • 2024 年 12 月 (1)
  • 2024 年 10 月 (1)
  • 2024 年 9 月 (1)
  • 2023 年 3 月 (2)
  • 2022 年 10 月 (1)
  • 2022 年 3 月 (1)
  • 2022 年 2 月 (1)
  • 2022 年 1 月 (5)
  • 2021 年 11 月 (7)
  • 2021 年 6 月 (3)
  • 2021 年 5 月 (2)
  • 2021 年 3 月 (2)
  • 2021 年 2 月 (8)
  • 2021 年 1 月 (18)

标签

3dtiles anr Bezier Curves BillBoard C++ CDN CivilDesigner DLL EasyX fog glTF MFC Midas W Midas XD NormalMapping ObjectARX ODA OpenGL OpenXML Open XML PBR revit WinDbg 基坑设计 影响线 截面特性 桥梁 桥梁检测 桥梁设计 算法 计算几何 设计模式

书签

  • 李燕良的CSDN
  • 崔济东的博客
  • C++爱好者博客
  • 陈学伟的博客
  • 贾苏的博客
  • 陈睦锋的博客
  • 孙勇的博客

统计

  • 0
  • 221
  • 98
  • 304
  • 127
  • 267,119
  • 76,989

实时访问地域

© 2025   liyanliang.net Copyright. All Rights Reserved.