麻辣GIS微信平台

更多 GIS 干货

微信关注不错过

VC++开发GIS系统(293)区量算之类的设计及实现

本文创建一个类用于实现区量算工作。功能演示如下:

GIS系统区量算类的定义

在 _malaAnalysis.h 中定义GIS自定义量算的类,代码如下:

/*
* 多边形量算
*/
class malaanalysisdll CmalaPolyMeasure :public CmalaMouseAction
{
public:
  CmalaPolyMeasure(CView* mView, malaScreen *pScreen, CString &fileFullPath);
  ~CmalaPolyMeasure();
  void LButtonDown(UINT nFlags, malaPoint point);
  void LButtonUp(UINT nFlags, malaPoint point);
  void MouseMove(UINT nFlags, malaPoint point);
private:
  malaPolyPro m_polypro;
  vector<malaPoint>m_poly;
  CmalaPolysSelect m_SelectPoly;
  bool m_Selected;
  bool m_bDraw;
  malaPoint m_ptOrigin;
  malaPoint m_perPoint;
  malaScreen *m_Screen;
  CString mPath;//文件路径
};
  • @ *m_Screen 屏幕坐标
  • @ m_PtOrigin 起点
  • @ m_PerPoint 临时的点
  • @ m_bDraw 标记是否按下左键
  • @ m_polypro 区的属性
  • @ m_poly 组成区的每一个点
  • @ m_SelectPoly 选择的区

类的实现

在 _malaAnalysis.cpp 中实现上述类的定义,代码如下:

/*
* 多边形量算
*/
CmalaPolyMeasure::CmalaPolyMeasure(CView* mView, malaScreen *pScreen, CString &fileFullPath)
{
  mBaseView = mView;

  mPath = fileFullPath;
  m_Screen = pScreen;

  CmalaPolysSelect obj(mBaseView, m_Screen, mPath);
  m_SelectPoly = obj;
  this->m_Selected = m_SelectPoly.m_Selected;
}

CmalaPolyMeasure::~CmalaPolyMeasure()
{

}

void CmalaPolyMeasure::LButtonDown(UINT nFlags, malaPoint point)
{
  if (!m_Selected)
    m_SelectPoly.LButtonDown(nFlags, point);
  else
  {
    m_bDraw = TRUE;
    m_ptOrigin = m_perPoint = point;
  }
}

void CmalaPolyMeasure::LButtonUp(UINT nFlags, malaPoint point)
{
  if (!m_Selected)
    m_SelectPoly.LButtonUp(nFlags, point);

  m_Selected = m_SelectPoly.m_Selected;
  if (m_Selected)
  {
    m_poly = m_SelectPoly.mSPoly;
    m_polypro = m_SelectPoly.mSPolyPro;
    malaLogic tMath;
    double area = tMath.ComputePolygonArea(m_poly);
    m_poly.push_back(m_poly[0]);
    double dis = tMath.distanceLine(m_poly);
    CString str;
    str.Format(L"面积:%f \n周长:%f", area, dis);
    MessageBox(mBaseView->m_hWnd, str, L"量算结果", MB_OK);
    m_Selected = FALSE;
    m_SelectPoly.m_Selected = FALSE;
  }
}

void CmalaPolyMeasure::MouseMove(UINT nFlags, malaPoint point)
{
  if (!m_Selected)
    m_SelectPoly.MouseMove(nFlags, point);
}

其中 distanceLine 的实现参考文章《VC++开发GIS系统(287)计算一条折线的长度》。ComputePolygonArea 用于计算多边形(区)的面积,可以参考文章《VC++开发GIS系统(292)计算任意多边形的面积

详细代码可以参考:GitHub

相关阅读

麻辣GIS-Sailor

作者:

GIS爱好者,学GIS,更爱玩GIS。

声明

1.本文所分享的所有需要用户下载使用的内容(包括但不限于软件、数据、图片)来自于网络或者麻辣GIS粉丝自行分享,版权归该下载资源的合法拥有者所有,如有侵权请第一时间联系本站删除。

2.下载内容仅限个人学习使用,请切勿用作商用等其他用途,否则后果自负。

手机阅读
公众号关注
知识星球
手机阅读
麻辣GIS微信公众号关注
最新GIS干货
关注麻辣GIS知识星球
私享圈子

留言板(小编看到第一时间回复)