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

Share the joys of programming and technology

去除重叠的闭合区域

去除重叠的闭合区域

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

题目描述

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

一、去除重叠的图形

//去除重叠的图形
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;
}

相关文章

  • 从DLL中动态加载一个函数:LoadLibrary和GetProcAddress的使用从DLL中动态加载一个函数:LoadLibrary和GetProcAddress的使用
  • C++实现一个简单的语言解释器C++实现一个简单的语言解释器
  • IBL计算总结IBL计算总结
  • C++编写的情人节小程序C++编写的情人节小程序
  • OpenGL绘制旋转立方体OpenGL绘制旋转立方体
  • 提取最小封闭区域提取最小封闭区域

计算几何
计算几何

Post navigation

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

发表回复 取消回复

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

近期文章

  • 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-满堂支架快速建模助手开发
  • OpenGL绘制桥梁模型
  • Modern OpenGL绘制圆柱体
  • WordPress分页插件 – WP-PageNavi的使用(替换现有脚本)

全站热点

  • C++编写的情人节小程序 (1,540)
  • Modern OpenGL绘制圆柱体 (759)
  • 提取最小封闭区域 (714)
  • 截面特性计算程序-附源码 (569)
  • 判断一个点是否在闭合区域内 (565)
  • OpenGL开发环境搭建-GLFW与GLAD配置 超详细 (503)
  • OpenGL绘制旋转立方体 (462)
  • Midas XD [错误] 右侧挡土墙的最下端深度必须小于地基的最下端深度 (438)
  • WordPress分页插件 – WP-PageNavi的使用(替换现有脚本) (395)
  • 使用ODA数据库出现 “ODA_ASSUME”: 找不到标识符的错误 (364)
  • 土木想往土木软件开发方向发展,应该如何准备 (361)
  • #pragma message 编译时提示信息 (336)
  • 从DLL中动态加载一个函数:LoadLibrary和GetProcAddress的使用 (331)
  • Midas W-满堂支架快速建模助手开发 (326)
  • midas XD2020的开发 (324)
  • 两跨连续梁影响线绘制-附源码 (320)
  • 算法:寻找异常数字 (260)
  • OpenGL几何着色器实现贝塞尔曲线 (200)
  • OpenGL实现billboard效果(CPU) (196)
  • 通过Spy++抓取窗口以查询对话框id (189)

分类

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

归档

  • 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)

标签

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

书签

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

统计

  • 0
  • 23
  • 10
  • 73
  • 29
  • 77,669
  • 24,003

实时访问地域

© 2023   liyanliang.net Copyright. All Rights Reserved.