麻辣GIS微信平台

更多 GIS 干货

微信关注不错过

VC++开发GIS系统(87)保存一个点到文件的函数

前文《VC++开发GIS系统(86)创建存储点文件的类》中为点文件的存储做了一个铺垫,下面的工作便是将一个点(包括坐标和属性)存储到文件中。

存储点的函数

在前文《VC++开发GIS系统(86)创建存储点文件的类》创建的 CPointIO 类中增加存储点的函数,实现如下:

//添加点实现
long CPointIO::pointAdd(malaPoint &Point, malaPointPro &PointPro, CString &fileName)
{
    int ID = getMaxID(fileName) + 1;
    CFile file;
    file.Open(LPCTSTR(fileName), CFile::modeCreate | CFile::modeWrite | CFile::modeNoTruncate);
    CArchive ar(&file, CArchive::store);
    file.SeekToEnd();
    ar << ID << PointPro.pointRadio << PointPro.pointStyle << PointPro.pointColor;
    ar << Point.x << Point.y;
    ar.Close();
    file.Close();

    return ID;
}

这个函数的作用是实现一个点到文件的存储过程,并返回这个点的ID。其中用到了一个getMaxID函数,是用来获取点文件中最大的ID。如下:

获取点的最大ID函数

//获取点的最大ID
long CPointIO::getMaxID(CString &fileName)
{
    int ID = 0;
    readPoints(fileName);
    
    int Size = mPoint.size();
    for (int i = 0; i < Size; i++)
    {
        if (mPoint[i].m_pointpro.pointId >= ID)
            ID = mPoint[i].m_pointpro.pointId;
    }
            
    return ID;
}

这其中又用到了一个readPoints函数,这个函数的作用是读取文件中所有已经存储的点到在《VC++开发GIS系统(86)创建存储点文件的类》中设置的私有变量中。实现如下:

缓存读取所有的点

//读取所有的点
void CPointIO::readPoints(CString &fileName)
{
    CFile file;
    file.Open(LPCTSTR(fileName), CFile::modeRead | CFile::modeCreate | CFile::modeNoTruncate);
    CArchive ar(&file, CArchive::load);
    if (mPoint.size())
        mPoint.clear();
    malaPoint pnt;
    malaPointPro pntpro;
    while (1)
    {
        try
        {
            ar >> pntpro.pointId >> pntpro.pointRadio >> pntpro.pointStyle >> pntpro.pointColor;
            ar >> pnt.x >> pnt.y;
        }
        catch (CMemoryException* e)
        {
            break;
        }
        catch (CFileException* e)
        {
            break;
        }
        catch (CException* e)
        {
            break;
        }
        malaPointFile MyPoint(pnt, pntpro);
        mPoint.push_back(MyPoint);
    }
}

详细代码可以参考:GitHub

相关阅读

麻辣GIS-Sailor

作者:

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

声明

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

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

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

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