亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mitab_tabfile.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
        delete m_poMAPFile;        m_poMAPFile = NULL;    }    if (m_poDATFile)    {        m_poDATFile->Close();        delete m_poDATFile;        m_poDATFile = NULL;    }    if (m_poINDFile)    {        m_poINDFile->Close();        delete m_poINDFile;        m_poINDFile = NULL;    }    if (m_poCurFeature)    {        delete m_poCurFeature;        m_poCurFeature = NULL;    }    /*-----------------------------------------------------------------     * Note: we have to check the reference count before deleting      * m_poSpatialRef and m_poDefn     *----------------------------------------------------------------*/    if (m_poDefn )    {        int nRefCount = m_poDefn->Dereference();        CPLAssert( nRefCount >= 0 );        if( nRefCount == 0 )            delete m_poDefn;        m_poDefn = NULL;    }        if (m_poSpatialRef && m_poSpatialRef->Dereference() == 0)        delete m_poSpatialRef;    m_poSpatialRef = NULL;        CSLDestroy(m_papszTABFile);    m_papszTABFile = NULL;    CPLFree(m_pszFname);    m_pszFname = NULL;    CPLFree(m_pszCharset);    m_pszCharset = NULL;    CPLFree(m_panIndexNo);    m_panIndexNo = NULL;    return 0;}/********************************************************************** *                   TABFile::GetNextFeatureId() * * Returns feature id that follows nPrevId, or -1 if it is the * last feature id.  Pass nPrevId=-1 to fetch the first valid feature id. **********************************************************************/int TABFile::GetNextFeatureId(int nPrevId){    if (m_eAccessMode != TABRead)    {        CPLError(CE_Failure, CPLE_NotSupported,                 "GetNextFeatureId() can be used only with Read access.");        return -1;    }    /*-----------------------------------------------------------------     * Are we using spatial rather than .ID based traversal?     *----------------------------------------------------------------*/    if( bUseSpatialTraversal )        return m_poMAPFile->GetNextFeatureId( nPrevId );    /*-----------------------------------------------------------------     * Establish what the next logical feature ID should be     *----------------------------------------------------------------*/    int nFeatureId = -1;    if (nPrevId <= 0 && m_nLastFeatureId > 0)        nFeatureId = 1;       // Feature Ids start at 1    else if (nPrevId > 0 && nPrevId < m_nLastFeatureId)        nFeatureId = nPrevId + 1;    else    {        // This was the last feature        return OGRNullFID;    }    /*-----------------------------------------------------------------     * Skip any feature with NONE geometry and a deleted attribute record     *----------------------------------------------------------------*/    while(nFeatureId <= m_nLastFeatureId)    {        if ( m_poMAPFile->MoveToObjId(nFeatureId) != 0 ||             m_poDATFile->GetRecordBlock(nFeatureId) == NULL )        {            CPLError(CE_Failure, CPLE_IllegalArg,                     "GetNextFeatureId() failed: unable to set read pointer "                     "to feature id %d",  nFeatureId);            return -1;        }// __TODO__ Add a test here to check if object is deleted, // i.e. 0x40 set on object_id in object block        if (m_poMAPFile->GetCurObjType() != TAB_GEOM_NONE ||            m_poDATFile->IsCurrentRecordDeleted() == FALSE)        {            // This feature contains at least a geometry or some attributes...            // return its id.            return nFeatureId;        }        nFeatureId++;    }    // If we reached this point, then we kept skipping deleted features    // and stopped when EOF was reached.    return -1;}/********************************************************************** *                   TABFile::GetNextFeatureId_Spatial() * * Returns feature id that follows nPrevId, or -1 if it is the * last feature id, but by traversing the spatial tree instead of the * direct object index.  Generally speaking the feature id's will be * returned in an unordered fashion.   **********************************************************************/int TABFile::GetNextFeatureId_Spatial(int nPrevId){    if (m_eAccessMode != TABRead)    {        CPLError(CE_Failure, CPLE_NotSupported,            "GetNextFeatureId_Spatial() can be used only with Read access.");        return -1;    }    if( m_poMAPFile == NULL )    {        CPLError(CE_Failure, CPLE_NotSupported,            "GetNextFeatureId_Spatial() requires availability of .MAP file." );        return -1;    }    return m_poMAPFile->GetNextFeatureId( nPrevId );}/********************************************************************** *                   TABFile::GetFeatureRef() * * Fill and return a TABFeature object for the specified feature id. * * The retruned pointer is a reference to an object owned and maintained * by this TABFile object.  It should not be altered or freed by the  * caller and its contents is guaranteed to be valid only until the next * call to GetFeatureRef() or Close(). * * Returns NULL if the specified feature id does not exist of if an * error happened.  In any case, CPLError() will have been called to * report the reason of the failure. * * If an unsupported object type is encountered (likely from a newer version * of MapInfo) then a valid feature will be returned with a NONE geometry, * and a warning will be produced with code TAB_WarningFeatureTypeNotSupported * CPLGetLastErrorNo() should be used to detect that case. **********************************************************************/TABFeature *TABFile::GetFeatureRef(int nFeatureId){    CPLErrorReset();    if (m_eAccessMode != TABRead)    {        CPLError(CE_Failure, CPLE_NotSupported,                 "GetFeatureRef() can be used only with Read access.");        return NULL;    }    /*-----------------------------------------------------------------     * Make sure file is opened and Validate feature id by positioning     * the read pointers for the .MAP and .DAT files to this feature id.     *----------------------------------------------------------------*/    if (m_poMAPFile == NULL)    {        CPLError(CE_Failure, CPLE_IllegalArg,                 "GetFeatureRef() failed: file is not opened!");        return NULL;    }    if (nFeatureId <= 0 || nFeatureId > m_nLastFeatureId ||        m_poMAPFile->MoveToObjId(nFeatureId) != 0 ||        m_poDATFile->GetRecordBlock(nFeatureId) == NULL )    {        //     CPLError(CE_Failure, CPLE_IllegalArg,        //    "GetFeatureRef() failed: invalid feature id %d",         //    nFeatureId);        return NULL;    }        /*-----------------------------------------------------------------     * Flush current feature object     * __TODO__ try to reuse if it is already of the right type     *----------------------------------------------------------------*/    if (m_poCurFeature)    {        delete m_poCurFeature;        m_poCurFeature = NULL;    }    /*-----------------------------------------------------------------     * Create new feature object of the right type     *----------------------------------------------------------------*/    switch(m_poMAPFile->GetCurObjType())    {      case TAB_GEOM_NONE:        m_poCurFeature = new TABFeature(m_poDefn);        break;      case TAB_GEOM_SYMBOL_C:      case TAB_GEOM_SYMBOL:        m_poCurFeature = new TABPoint(m_poDefn);        break;      case TAB_GEOM_FONTSYMBOL_C:      case TAB_GEOM_FONTSYMBOL:        m_poCurFeature = new TABFontPoint(m_poDefn);        break;      case TAB_GEOM_CUSTOMSYMBOL_C:      case TAB_GEOM_CUSTOMSYMBOL:        m_poCurFeature = new TABCustomPoint(m_poDefn);        break;      case TAB_GEOM_LINE_C:      case TAB_GEOM_LINE:      case TAB_GEOM_PLINE_C:      case TAB_GEOM_PLINE:      case TAB_GEOM_MULTIPLINE_C:      case TAB_GEOM_MULTIPLINE:      case TAB_GEOM_V450_MULTIPLINE_C:      case TAB_GEOM_V450_MULTIPLINE:       m_poCurFeature = new TABPolyline(m_poDefn);        break;      case TAB_GEOM_ARC_C:      case TAB_GEOM_ARC:        m_poCurFeature = new TABArc(m_poDefn);        break;      case TAB_GEOM_REGION_C:      case TAB_GEOM_REGION:      case TAB_GEOM_V450_REGION_C:      case TAB_GEOM_V450_REGION:        m_poCurFeature = new TABRegion(m_poDefn);        break;      case TAB_GEOM_RECT_C:      case TAB_GEOM_RECT:      case TAB_GEOM_ROUNDRECT_C:      case TAB_GEOM_ROUNDRECT:        m_poCurFeature = new TABRectangle(m_poDefn);        break;      case TAB_GEOM_ELLIPSE_C:      case TAB_GEOM_ELLIPSE:        m_poCurFeature = new TABEllipse(m_poDefn);        break;      case TAB_GEOM_TEXT_C:      case TAB_GEOM_TEXT:        m_poCurFeature = new TABText(m_poDefn);        break;      case TAB_GEOM_MULTIPOINT_C:      case TAB_GEOM_MULTIPOINT:        m_poCurFeature = new TABMultiPoint(m_poDefn);        break;      case TAB_GEOM_COLLECTION_C:      case TAB_GEOM_COLLECTION:        m_poCurFeature = new TABCollection(m_poDefn);          break;      default:        /*-------------------------------------------------------------         * Unsupported feature type... we still return a valid feature         * with NONE geometry after producing a Warning.         * Callers can trap that case by checking CPLGetLastErrorNo()          * against TAB_WarningFeatureTypeNotSupported         *------------------------------------------------------------*///        m_poCurFeature = new TABDebugFeature(m_poDefn);        m_poCurFeature = new TABFeature(m_poDefn);        CPLError(CE_Warning, TAB_WarningFeatureTypeNotSupported,                 "Unsupported object type %d (0x%2.2x).  Feature will be "                 "returned with NONE geometry.",                  m_poMAPFile->GetCurObjType(), m_poMAPFile->GetCurObjType() );    }    /*-----------------------------------------------------------------     * Read fields from the .DAT file     * GetRecordBlock() has already been called above...     *----------------------------------------------------------------*/    if (m_poCurFeature->ReadRecordFromDATFile(m_poDATFile) != 0)    {        delete m_poCurFeature;        m_poCurFeature = NULL;        return NULL;    }    /*-----------------------------------------------------------------     * Read geometry from the .MAP file     * MoveToObjId() has already been called above...     *----------------------------------------------------------------*/    TABMAPObjHdr *poObjHdr =         TABMAPObjHdr::NewObj(m_poMAPFile->GetCurObjType(),                              m_poMAPFile->GetCurObjId());    // Note that poObjHdr==NULL is a valid case if geometry type is NONE    if ((poObjHdr && poObjHdr->ReadObj(m_poMAPFile->GetCurObjBlock()) != 0) ||        m_poCurFeature->ReadGeometryFromMAPFile(m_poMAPFile, poObjHdr) != 0)    {        delete m_poCurFeature;        m_poCurFeature = NULL;        if (poObjHdr)             delete poObjHdr;        return NULL;    }    if (poObjHdr)       // May be NULL if feature geometry type is NONE        delete poObjHdr;     m_nCurFeatureId = nFeatureId;    m_poCurFeature->SetFID(m_nCurFeatureId);    m_poCurFeature->SetRecordDeleted(m_poDATFile->IsCurrentRecordDeleted());    return m_poCurFeature;}/********************************************************************** *                   TABFile::SetFeature() * * Write a feature to this dataset.   * * For now only sequential writes are supported (i.e. with nFeatureId=-1) * but eventually we should be able to do random access by specifying * a value through nFeatureId. * * Returns the new featureId (> 0) on success, or -1 if an * error happened in which case, CPLError() will have been called to * report the reason of the failure. **********************************************************************/int TABFile::SetFeature(TABFeature *poFeature, int nFeatureId /*=-1*/){    if (m_eAccessMode != TABWrite)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品亚洲精品国产欧美kt∨| 国产一区二区三区视频在线播放| 国产精品一级片在线观看| 欧美日本精品一区二区三区| 亚洲另类在线视频| 99久久伊人网影院| 国产精品国产馆在线真实露脸| 国产精品一线二线三线| 亚洲精品一区二区三区香蕉| 久久av中文字幕片| 精品嫩草影院久久| 国产一区二区三区高清播放| 99国产精品久久久久久久久久| 精品理论电影在线观看| 久久精品国内一区二区三区| 精品日韩av一区二区| 韩国一区二区在线观看| 久久日一线二线三线suv| 精品一区二区三区的国产在线播放| 欧日韩精品视频| 亚洲gay无套男同| 91精品国产综合久久久久久久久久| 五月婷婷综合激情| 日韩精品专区在线| 国产精品一区免费视频| 日韩欧美成人一区二区| 久久se这里有精品| 久久精品一区蜜桃臀影院| 成人精品高清在线| 亚洲欧美日韩国产另类专区| 欧美在线制服丝袜| 麻豆国产精品官网| 久久久久久久综合狠狠综合| eeuss鲁片一区二区三区 | 亚洲精品欧美二区三区中文字幕| 日本韩国一区二区| 日本vs亚洲vs韩国一区三区二区| 久久在线免费观看| 92国产精品观看| 日韩精品1区2区3区| 精品国产伦一区二区三区免费 | 午夜视黄欧洲亚洲| 精品国产区一区| 91一区二区三区在线播放| 亚洲国产日韩一区二区| 欧美成人女星排名| 99久久夜色精品国产网站| 丝袜亚洲另类欧美综合| 国产欧美日韩在线观看| 99久久国产综合精品麻豆| 亚洲一区二区精品视频| 欧美大胆人体bbbb| 成人黄色大片在线观看| 丝袜a∨在线一区二区三区不卡| 精品精品欲导航| 91麻豆精品秘密| 精品一区二区三区在线观看| 亚洲伦理在线精品| 亚洲精品一区二区三区99| 91免费视频网| 久久99久久久欧美国产| 伊人性伊人情综合网| 久久综合九色综合欧美98| 一本一道久久a久久精品综合蜜臀| 日日夜夜免费精品| 亚洲人成网站影音先锋播放| 久久综合九色综合久久久精品综合| 色哟哟国产精品| 国产东北露脸精品视频| 日韩国产欧美在线观看| 一区二区三区在线视频免费| 国产色爱av资源综合区| 欧美在线免费视屏| 成人av电影在线| 国产精品99久久久久久似苏梦涵 | 日本一区二区三级电影在线观看| 在线亚洲免费视频| 成人免费视频免费观看| 狠狠色丁香婷婷综合| 污片在线观看一区二区| 亚洲激情网站免费观看| 亚洲国产岛国毛片在线| 精品人在线二区三区| 91精品婷婷国产综合久久性色| 一本久道中文字幕精品亚洲嫩| 国产一区二区91| 久久99国内精品| 免费不卡在线视频| 午夜精品久久久久久久| 亚洲国产欧美日韩另类综合 | 久久亚洲综合av| 日韩美女在线视频 | 激情五月激情综合网| 日韩成人一级片| 日韩精品亚洲一区| 日韩精品成人一区二区三区| 亚洲18色成人| 亚洲一区在线观看视频| 亚洲桃色在线一区| 亚洲乱码中文字幕| 一区二区三区国产精华| 亚洲精品免费在线| 亚洲欧美日韩国产成人精品影院 | 91精品国产综合久久香蕉麻豆| 欧美亚洲一区二区在线| 97久久超碰国产精品电影| 不卡视频在线看| 色一情一乱一乱一91av| 欧美自拍丝袜亚洲| 欧美妇女性影城| 日韩欧美国产精品| 久久久久久久久97黄色工厂| 久久久久久久久久久久久女国产乱| 欧美xingq一区二区| www久久精品| 国产精品久久久久一区| 亚洲男人的天堂一区二区| 亚洲精品一二三区| 污片在线观看一区二区| 久久精品国产999大香线蕉| 国产主播一区二区| 99久久精品免费| 色伊人久久综合中文字幕| 9191成人精品久久| 久久久亚洲综合| 日韩毛片一二三区| 婷婷成人综合网| 久久99国产精品免费| 成人黄色大片在线观看| 欧美在线观看视频一区二区| 日韩一级免费观看| 中文字幕av一区二区三区| 自拍偷拍亚洲综合| 日本不卡免费在线视频| 丰满亚洲少妇av| 欧美影视一区在线| 亚洲精品在线电影| 亚洲女人的天堂| 免费人成在线不卡| 成人av免费观看| 91精品国产91久久综合桃花| 久久精品人人做人人爽人人| 一区二区三区不卡在线观看| 麻豆精品久久精品色综合| 国产一区二区在线看| 91久久精品一区二区二区| 日韩精品一区二区三区三区免费| 国产精品理论在线观看| 国产一区二区精品久久| 日韩午夜激情av| 日韩国产精品久久| 欧美在线观看视频在线| 亚洲欧美成aⅴ人在线观看 | 成人h精品动漫一区二区三区| 日韩一区二区三区在线视频| 性欧美大战久久久久久久久| 一本大道久久a久久综合婷婷| 亚洲国产高清aⅴ视频| 国产精品综合二区| 日韩一区和二区| 亚洲国产视频一区| 91在线观看免费视频| 久久影音资源网| 男女性色大片免费观看一区二区| 国产乱码精品一区二区三区忘忧草| 色美美综合视频| 国产精品久久久久久久蜜臀| 国模冰冰炮一区二区| 精品福利一区二区三区| 国产精品美女www爽爽爽| 国产乱对白刺激视频不卡| 欧美精品一区二区三区蜜桃视频 | 免费在线观看一区二区三区| 制服丝袜激情欧洲亚洲| 日日夜夜免费精品| 91精品国产91综合久久蜜臀| 奇米影视一区二区三区| 日韩视频在线你懂得| 久久99精品久久久久久动态图 | 99久久婷婷国产综合精品电影| 国产精品麻豆久久久| 99久久精品免费| 亚洲图片有声小说| 69成人精品免费视频| 精品一二三四区| 中文天堂在线一区| 色偷偷一区二区三区| 亚洲一区二区三区免费视频| 欧美一区二区在线播放| 老司机午夜精品| 国产欧美视频一区二区三区| av资源网一区| 亚洲午夜久久久久久久久电影网| 欧美日本一区二区在线观看| 精品一区二区三区日韩| 国产精品久久久久久久久久免费看| 色94色欧美sute亚洲线路一ni| 视频在线在亚洲| 国产网站一区二区| 在线观看免费视频综合|