麻辣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。
微博关注
手机阅读
赞赏支持
手机阅读
微信捐助麻辣GIS
微信打赏
支付宝捐助麻辣GIS
支付宝打赏

声明

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

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

3.如果本文对您有所帮助,请您对我们团队进行 打赏捐助让我们在传播3S的路上可以走得更远,不胜感激。PS:如果你是学生党,请优先把经费用于购买学习资料 以及 与小哥哥/小姐姐约会上:-)

如您有疑问,可在文末留言,或到麻辣GIS QQ群中提问。

QQ群(一):291616564 加入QQ群

QQ群(二):166408035 加入QQ群

QQ群(三):627853279 加入QQ群

QQ群(四):436386604 加入QQ群

QQ群(五):606176554 加入QQ群

QQ群(六):946178380 加入QQ群

QQ群(七):861271808 加入QQ群

新疆互助群:910717627 加入QQ群

微信公众号:malagis,扫描右边二维码直接关注。

发表评论