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

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

?? ogrshapelayer.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
OGRSpatialReference *OGRShapeLayer::GetSpatialRef(){    return poSRS;}/************************************************************************//*                           ResetGeomType()                            *//*                                                                      *//*      Modify the geometry type for this file.  Used to convert to     *//*      a different geometry type when a layer was created with a       *//*      type of unknown, and we get to the first feature to             *//*      establish the type.                                             *//************************************************************************/int OGRShapeLayer::ResetGeomType( int nNewGeomType ){    char        abyHeader[100];    int         nStartPos;    if( nTotalShapeCount > 0 )        return FALSE;/* -------------------------------------------------------------------- *//*      Update .shp header.                                             *//* -------------------------------------------------------------------- */    nStartPos = ftell( hSHP->fpSHP );    if( fseek( hSHP->fpSHP, 0, SEEK_SET ) != 0        || fread( abyHeader, 100, 1, hSHP->fpSHP ) != 1 )        return FALSE;    *((GInt32 *) (abyHeader + 32)) = CPL_LSBWORD32( nNewGeomType );    if( fseek( hSHP->fpSHP, 0, SEEK_SET ) != 0        || fwrite( abyHeader, 100, 1, hSHP->fpSHP ) != 1 )        return FALSE;    if( fseek( hSHP->fpSHP, nStartPos, SEEK_SET ) != 0 )        return FALSE;/* -------------------------------------------------------------------- *//*      Update .shx header.                                             *//* -------------------------------------------------------------------- */    nStartPos = ftell( hSHP->fpSHX );    if( fseek( hSHP->fpSHX, 0, SEEK_SET ) != 0        || fread( abyHeader, 100, 1, hSHP->fpSHX ) != 1 )        return FALSE;    *((GInt32 *) (abyHeader + 32)) = CPL_LSBWORD32( nNewGeomType );    if( fseek( hSHP->fpSHX, 0, SEEK_SET ) != 0        || fwrite( abyHeader, 100, 1, hSHP->fpSHX ) != 1 )        return FALSE;    if( fseek( hSHP->fpSHX, nStartPos, SEEK_SET ) != 0 )        return FALSE;/* -------------------------------------------------------------------- *//*      Update other information.                                       *//* -------------------------------------------------------------------- */    hSHP->nShapeType = nNewGeomType;    return TRUE;}/************************************************************************//*                             SyncToDisk()                             *//************************************************************************/OGRErr OGRShapeLayer::SyncToDisk(){    if( bHeaderDirty )    {        if( hSHP != NULL )            SHPWriteHeader( hSHP );        if( hDBF != NULL )            DBFUpdateHeader( hDBF );                bHeaderDirty = FALSE;    }    if( hSHP != NULL )    {        fflush( hSHP->fpSHP );        fflush( hSHP->fpSHX );    }    if( hDBF != NULL )        fflush( hDBF->fp );    return OGRERR_NONE;}/************************************************************************//*                          DropSpatialIndex()                          *//************************************************************************/OGRErr OGRShapeLayer::DropSpatialIndex(){    if( !CheckForQIX() )    {        CPLError( CE_Warning, CPLE_AppDefined,                   "Layer %s has no spatial index, DROP SPATIAL INDEX failed.",                  poFeatureDefn->GetName() );        return OGRERR_FAILURE;    }    VSIFClose( fpQIX );    fpQIX = NULL;    bCheckedForQIX = FALSE;        const char *pszQIXFilename;    pszQIXFilename = CPLResetExtension( pszFullName, "qix" );    CPLDebug( "SHAPE", "Unlinking index file %s", pszQIXFilename );    if( VSIUnlink( pszQIXFilename ) != 0 )    {        CPLError( CE_Failure, CPLE_AppDefined,                  "Failed to delete file %s.\n%s",                   pszQIXFilename, VSIStrerror( errno ) );        return OGRERR_FAILURE;    }    else        return OGRERR_NONE;}/************************************************************************//*                         CreateSpatialIndex()                         *//************************************************************************/OGRErr OGRShapeLayer::CreateSpatialIndex( int nMaxDepth ){/* -------------------------------------------------------------------- *//*      If we have an existing spatial index, blow it away first.       *//* -------------------------------------------------------------------- */    if( CheckForQIX() )        DropSpatialIndex();    bCheckedForQIX = FALSE;/* -------------------------------------------------------------------- *//*      Build a quadtree structure for this file.                       *//* -------------------------------------------------------------------- */    SHPTree	*psTree;    SyncToDisk();    psTree = SHPCreateTree( hSHP, 2, nMaxDepth, NULL, NULL );/* -------------------------------------------------------------------- *//*      Trim unused nodes from the tree.                                *//* -------------------------------------------------------------------- */    SHPTreeTrimExtraNodes( psTree );/* -------------------------------------------------------------------- *//*      Dump tree to .qix file.                                         *//* -------------------------------------------------------------------- */    char *pszQIXFilename;    pszQIXFilename = CPLStrdup(CPLResetExtension( pszFullName, "qix" ));    CPLDebug( "SHAPE", "Creating index file %s", pszQIXFilename );    SHPWriteTree( psTree, pszQIXFilename );    CPLFree( pszQIXFilename );/* -------------------------------------------------------------------- *//*      cleanup                                                         *//* -------------------------------------------------------------------- */    SHPDestroyTree( psTree );    CheckForQIX();    return OGRERR_NONE;}/************************************************************************//*                               Repack()                               *//*                                                                      *//*      Repack the shape and dbf file, dropping deleted records.        *//*      FIDs may change.                                                *//************************************************************************/OGRErr OGRShapeLayer::Repack(){/* -------------------------------------------------------------------- *//*      Build a list of records to be dropped.                          *//* -------------------------------------------------------------------- */    int *panRecordsToDelete = (int *)         CPLMalloc(sizeof(int)*(nTotalShapeCount+1));    int nDeleteCount = 0;    int iShape;    OGRErr eErr = OGRERR_NONE;    for( iShape = 0; iShape < nTotalShapeCount; iShape++ )    {        if( DBFIsRecordDeleted( hDBF, iShape ) )            panRecordsToDelete[nDeleteCount++] = iShape;    }    panRecordsToDelete[nDeleteCount] = -1;/* -------------------------------------------------------------------- *//*      If there are no records marked for deletion, we take no         *//*      action.                                                         *//* -------------------------------------------------------------------- */    if( nDeleteCount == 0 )        return OGRERR_NONE;/* -------------------------------------------------------------------- *//*      Cleanup any existing spatial index.  It will become             *//*      meaningless when the fids change.                               *//* -------------------------------------------------------------------- */    if( CheckForQIX() )        DropSpatialIndex();/* -------------------------------------------------------------------- *//*      Create a new dbf file, matching the old.                        *//* -------------------------------------------------------------------- */    DBFHandle hNewDBF;    CPLString oTempFile = CPLGetBasename(pszFullName);    oTempFile += "_packed.dbf";    hNewDBF = DBFCloneEmpty( hDBF, oTempFile );    if( hNewDBF == NULL )    {        CPLFree( panRecordsToDelete );        CPLError( CE_Failure, CPLE_OpenFailed,                   "Failed to create temp file %s.",                   oTempFile.c_str() );        return OGRERR_FAILURE;    }/* -------------------------------------------------------------------- *//*      Copy over all records that are not deleted.                     *//* -------------------------------------------------------------------- */    int iDestShape = 0;    int iNextDeletedShape = 0;    for( iShape = 0;          iShape < nTotalShapeCount && eErr == OGRERR_NONE;          iShape++ )    {        if( panRecordsToDelete[iNextDeletedShape] == iShape )            iNextDeletedShape++;        else        {            void *pTuple = (void *) DBFReadTuple( hDBF, iShape );            if( pTuple == NULL )                eErr = OGRERR_FAILURE;            else if( !DBFWriteTuple( hNewDBF, iDestShape++, pTuple ) )                eErr = OGRERR_FAILURE;        }                               }    if( eErr != OGRERR_NONE )    {        CPLFree( panRecordsToDelete );        VSIUnlink( oTempFile );        return eErr;    }/* -------------------------------------------------------------------- *//*      Cleanup the old .dbf and rename the new one.                    *//* -------------------------------------------------------------------- */    DBFClose( hDBF );    hDBF = hNewDBF;    VSIUnlink( CPLResetExtension( pszFullName, "dbf" ) );    if( VSIRename( oTempFile, CPLResetExtension( pszFullName, "dbf" ) ) != 0 )        return OGRERR_FAILURE;/* -------------------------------------------------------------------- *//*      Now create a shapefile matching the old one.                    *//* -------------------------------------------------------------------- */    if( hSHP != NULL )    {        SHPHandle hNewSHP;        oTempFile = CPLGetBasename(pszFullName);        oTempFile += "_packed.shp";        hNewSHP = SHPCreate( oTempFile, hSHP->nShapeType );        if( hNewSHP == NULL )            return OGRERR_FAILURE;/* -------------------------------------------------------------------- *//*      Copy over all records that are not deleted.                     *//* -------------------------------------------------------------------- */        iNextDeletedShape = 0;        for( iShape = 0;              iShape < nTotalShapeCount && eErr == OGRERR_NONE;              iShape++ )        {            if( panRecordsToDelete[iNextDeletedShape] == iShape )                iNextDeletedShape++;            else            {                SHPObject *hObject;                hObject = SHPReadObject( hSHP, iShape );                if( hObject == NULL )                    eErr = OGRERR_FAILURE;                else if( SHPWriteObject( hNewSHP, -1, hObject ) == -1 )                    eErr = OGRERR_FAILURE;                if( hObject )                    SHPDestroyObject( hObject );            }        }        if( eErr != OGRERR_NONE )        {            CPLFree( panRecordsToDelete );            VSIUnlink( CPLResetExtension( oTempFile, "shp" ) );            VSIUnlink( CPLResetExtension( oTempFile, "shx" ) );            return eErr;        }/* -------------------------------------------------------------------- *//*      Cleanup the old .shp/.shx and rename the new one.               *//* -------------------------------------------------------------------- */        SHPClose( hSHP );        hSHP = hNewSHP;        VSIUnlink( CPLResetExtension( pszFullName, "shp" ) );        VSIUnlink( CPLResetExtension( pszFullName, "shx" ) );        if( VSIRename( oTempFile,                        CPLResetExtension( pszFullName, "shp" ) ) != 0 )            return OGRERR_FAILURE;            oTempFile = CPLResetExtension( oTempFile, "shx" );        if( VSIRename( oTempFile,                        CPLResetExtension( pszFullName, "shx" ) ) != 0 )            return OGRERR_FAILURE;    }/* -------------------------------------------------------------------- *//*      Update total shape count.                                       *//* -------------------------------------------------------------------- */    nTotalShapeCount = hDBF->nRecords;    CPLFree( panRecordsToDelete );    return OGRERR_NONE;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品久久久蜜桃| 日韩欧美高清一区| 亚洲精品一二三| 在线观看亚洲精品| 亚洲成av人片一区二区三区| 91麻豆精品国产自产在线观看一区| 日韩精品五月天| 欧美成人一区二区三区在线观看 | 精品国偷自产国产一区| 久久精品免费看| 国产欧美在线观看一区| 91麻豆国产福利在线观看| 亚洲国产精品影院| 日韩欧美一级在线播放| 成人毛片老司机大片| 亚洲精品伦理在线| 日韩一区二区三区观看| 丁香桃色午夜亚洲一区二区三区| 综合色天天鬼久久鬼色| 911精品国产一区二区在线| 老司机免费视频一区二区 | 国产成人亚洲综合色影视| 中文字幕在线观看不卡视频| 欧日韩精品视频| 蓝色福利精品导航| 亚洲美女屁股眼交3| 精品sm在线观看| 日本乱人伦aⅴ精品| 久久精品国产第一区二区三区| 国产精品成人午夜| 91精品国产91久久综合桃花| 成人中文字幕电影| 奇米一区二区三区av| 国产精品初高中害羞小美女文| 51午夜精品国产| 91麻豆国产在线观看| 国内成人精品2018免费看| 亚洲另类春色国产| 国产视频一区二区在线| 在线播放视频一区| 色欧美片视频在线观看| 国产精品亚洲人在线观看| 亚洲线精品一区二区三区| 国产精品伦理一区二区| 欧美大肚乱孕交hd孕妇| 欧美在线观看一二区| 丁香啪啪综合成人亚洲小说| 美女脱光内衣内裤视频久久网站| 一个色妞综合视频在线观看| 国产精品日韩成人| 久久美女艺术照精彩视频福利播放 | 色婷婷av一区二区三区大白胸 | 成人动漫av在线| 久久国内精品视频| 亚洲不卡在线观看| 一区二区三区在线观看网站| 日韩一区在线播放| 中文字幕va一区二区三区| 26uuu精品一区二区三区四区在线| 欧美亚洲综合色| 91在线视频18| 成人免费视频app| 国产精品一线二线三线| 久久精品国产色蜜蜜麻豆| 性久久久久久久久| 亚洲电影你懂得| 亚洲主播在线播放| 亚洲最大色网站| 亚洲综合在线免费观看| 亚洲色图制服诱惑| 自拍av一区二区三区| 国产精品伦理在线| 中文字幕一区二区三区在线不卡| 国产精品久久久久天堂| 中文乱码免费一区二区| 国产精品久久久爽爽爽麻豆色哟哟| 久久夜色精品一区| 国产丝袜美腿一区二区三区| 国产日韩欧美综合在线| 中文字幕精品一区| 欧美国产1区2区| 日本一区二区三区高清不卡| 国产日产亚洲精品系列| 国产偷国产偷精品高清尤物| 国产精品免费观看视频| 中文字幕欧美国产| 亚洲欧美另类图片小说| 亚洲国产日韩av| 日本视频一区二区三区| 蜜臀99久久精品久久久久久软件| 精品在线视频一区| 国产一区二区成人久久免费影院| 国产乱一区二区| 99久久综合精品| 欧美视频一区二区三区在线观看| 欧美精品在线观看播放| 精品理论电影在线观看 | 日韩欧美国产精品一区| 精品国产三级电影在线观看| 国产调教视频一区| 亚洲综合免费观看高清完整版在线| 亚洲成人动漫在线观看| 国内成人精品2018免费看| 99久久久国产精品免费蜜臀| 欧美视频日韩视频| 日韩精品一区二区三区swag| 中文字幕va一区二区三区| 亚洲最大色网站| 久久精品国产77777蜜臀| 国产成人精品影视| 欧美亚洲自拍偷拍| 久久精品视频免费观看| 亚洲中国最大av网站| 精品中文字幕一区二区| 99久久综合99久久综合网站| 欧美精品一卡两卡| 国产精品久久久久一区二区三区 | 一色桃子久久精品亚洲| 亚洲国产精品嫩草影院| 国产乱人伦偷精品视频免下载| 91在线视频网址| 久久中文字幕电影| 亚洲欧美日韩电影| 精品一区二区三区视频在线观看| 91网站最新网址| 精品国产伦一区二区三区观看体验| 日韩美女啊v在线免费观看| 蜜芽一区二区三区| 91国内精品野花午夜精品| 精品91自产拍在线观看一区| 亚洲综合网站在线观看| 国产成人午夜高潮毛片| 欧美欧美午夜aⅴ在线观看| 国产精品萝li| 国产伦精品一区二区三区免费迷| 欧美曰成人黄网| 国产精品久久夜| 国产精品18久久久久久久久久久久 | 日韩欧美国产精品| 一二三区精品视频| youjizz国产精品| 26uuu久久综合| 免费人成网站在线观看欧美高清| 91丨porny丨蝌蚪视频| 国产偷国产偷亚洲高清人白洁| 日本va欧美va瓶| 欧美日本乱大交xxxxx| 亚洲精选免费视频| 懂色av一区二区三区蜜臀| 精品国产一区二区三区四区四| 午夜精品久久久久久久久久久 | 亚洲免费观看视频| 成人av手机在线观看| 久久精品亚洲麻豆av一区二区| 日本中文在线一区| 欧美日韩一区精品| 亚洲电影你懂得| 欧美日韩中文一区| 一区二区日韩电影| 在线亚洲免费视频| 亚洲午夜电影在线| 在线观看日韩高清av| 亚洲一区二区五区| 欧洲在线/亚洲| 亚洲曰韩产成在线| 欧美在线三级电影| 亚洲国产日韩a在线播放性色| 欧美午夜精品一区二区三区| 亚洲欧美色图小说| 91同城在线观看| 亚洲欧美偷拍三级| 欧美午夜精品久久久久久孕妇| 一区二区三区在线视频观看| 色综合久久六月婷婷中文字幕| 亚洲欧美二区三区| 色综合天天综合色综合av| 亚洲欧美视频在线观看| 日本韩国一区二区| 五月综合激情日本mⅴ| 8x8x8国产精品| 久久激情五月婷婷| 欧美经典三级视频一区二区三区| 国产成人亚洲综合色影视 | 亚洲免费观看高清| 欧美日韩在线三级| 免费成人av资源网| 国产日韩精品一区二区浪潮av| 97se亚洲国产综合自在线| 一区二区三区四区在线播放 | 色综合欧美在线视频区| 亚洲国产精品久久久久婷婷884| 555夜色666亚洲国产免| 国产电影一区二区三区| 亚洲人123区| 欧美一区二区精美| av在线不卡网| 五月婷婷综合网| 国产精品无码永久免费888| 色婷婷综合激情| 国产一区美女在线|