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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ogrshapelayer.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 3 頁
字號(hào):
    /*     * Reading shape feature failed.     */    return NULL;}/************************************************************************//*                             SetFeature()                             *//************************************************************************/OGRErr OGRShapeLayer::SetFeature( OGRFeature *poFeature ){    bHeaderDirty = TRUE;    return SHPWriteOGRFeature( hSHP, hDBF, poFeatureDefn, poFeature );}/************************************************************************//*                           DeleteFeature()                            *//************************************************************************/OGRErr OGRShapeLayer::DeleteFeature( long nFID ){    if( nFID < 0         || (hSHP != NULL && nFID >= hSHP->nRecords)        || (hDBF != NULL && nFID >= hDBF->nRecords) )    {        CPLError( CE_Failure, CPLE_AppDefined,                   "Attempt to delete shape with feature id (%d) which does "                  "not exist.", nFID );        return OGRERR_FAILURE;    }    if( !hDBF )    {        CPLError( CE_Failure, CPLE_AppDefined,                   "Attempt to delete shape in shapefile with no .dbf file.\n"                  "Deletion is done by marking record deleted in dbf\n"                  "and is not supported without a .dbf file." );        return OGRERR_FAILURE;    }    if( DBFIsRecordDeleted( hDBF, nFID ) )    {        CPLError( CE_Failure, CPLE_AppDefined,                   "Attempt to delete shape with feature id (%d), but it is marked deleted already.",                  nFID );        return OGRERR_FAILURE;    }    if( !DBFMarkRecordDeleted( hDBF, nFID, TRUE ) )        return OGRERR_FAILURE;    bHeaderDirty = TRUE;    return OGRERR_NONE;}/************************************************************************//*                           CreateFeature()                            *//************************************************************************/OGRErr OGRShapeLayer::CreateFeature( OGRFeature *poFeature ){    OGRErr eErr;    bHeaderDirty = TRUE;    poFeature->SetFID( OGRNullFID );    if( nTotalShapeCount == 0         && eRequestedGeomType == wkbUnknown         && poFeature->GetGeometryRef() != NULL )    {        OGRGeometry     *poGeom = poFeature->GetGeometryRef();        int             nShapeType;                switch( poGeom->getGeometryType() )        {          case wkbPoint:            nShapeType = SHPT_POINT;            eRequestedGeomType = wkbPoint;            break;          case wkbPoint25D:            nShapeType = SHPT_POINTZ;            eRequestedGeomType = wkbPoint25D;            break;          case wkbMultiPoint:            nShapeType = SHPT_MULTIPOINT;            eRequestedGeomType = wkbMultiPoint;            break;          case wkbMultiPoint25D:            nShapeType = SHPT_MULTIPOINTZ;            eRequestedGeomType = wkbMultiPoint25D;            break;          case wkbLineString:            nShapeType = SHPT_ARC;            eRequestedGeomType = wkbLineString;            break;          case wkbLineString25D:            nShapeType = SHPT_ARCZ;            eRequestedGeomType = wkbLineString25D;            break;          case wkbPolygon:          case wkbMultiPolygon:            nShapeType = SHPT_POLYGON;            eRequestedGeomType = wkbPolygon;            break;          case wkbPolygon25D:          case wkbMultiPolygon25D:            nShapeType = SHPT_POLYGONZ;            eRequestedGeomType = wkbPolygon25D;            break;          default:            nShapeType = -1;            break;        }        if( nShapeType != -1 )        {            ResetGeomType( nShapeType );        }    }        eErr = SHPWriteOGRFeature( hSHP, hDBF, poFeatureDefn, poFeature );    if( hSHP != NULL )        nTotalShapeCount = hSHP->nRecords;    else         nTotalShapeCount = hDBF->nRecords;        return eErr;}/************************************************************************//*                          GetFeatureCount()                           *//*                                                                      *//*      If a spatial filter is in effect, we turn control over to       *//*      the generic counter.  Otherwise we return the total count.      *//*      Eventually we should consider implementing a more efficient     *//*      way of counting features matching a spatial query.              *//************************************************************************/int OGRShapeLayer::GetFeatureCount( int bForce ){    if( m_poFilterGeom != NULL || m_poAttrQuery != NULL )        return OGRLayer::GetFeatureCount( bForce );    else        return nTotalShapeCount;}/************************************************************************//*                             GetExtent()                              *//*                                                                      *//*      Fetch extent of the data currently stored in the dataset.       *//*      The bForce flag has no effect on SHO files since that value     *//*      is always in the header.                                        *//*                                                                      *//*      Returns OGRERR_NONE/OGRRERR_FAILURE.                            *//************************************************************************/OGRErr OGRShapeLayer::GetExtent (OGREnvelope *psExtent, int bForce){    double adMin[4], adMax[4];    if( hSHP == NULL )        return OGRERR_FAILURE;    SHPGetInfo(hSHP, NULL, NULL, adMin, adMax);    psExtent->MinX = adMin[0];    psExtent->MinY = adMin[1];    psExtent->MaxX = adMax[0];    psExtent->MaxY = adMax[1];    return OGRERR_NONE;}/************************************************************************//*                           TestCapability()                           *//************************************************************************/int OGRShapeLayer::TestCapability( const char * pszCap ){    if( EQUAL(pszCap,OLCRandomRead) )        return TRUE;    else if( EQUAL(pszCap,OLCSequentialWrite)              || EQUAL(pszCap,OLCRandomWrite) )        return bUpdateAccess;    else if( EQUAL(pszCap,OLCFastFeatureCount) )        return m_poFilterGeom == NULL;    else if( EQUAL(pszCap,OLCDeleteFeature) )        return TRUE;    else if( EQUAL(pszCap,OLCFastSpatialFilter) )        return FALSE;    else if( EQUAL(pszCap,OLCFastGetExtent) )        return TRUE;    else if( EQUAL(pszCap,OLCFastSetNextByIndex) )        return m_poFilterGeom == NULL && m_poAttrQuery == NULL;    else if( EQUAL(pszCap,OLCCreateField) )        return TRUE;    else         return FALSE;}/************************************************************************//*                            CreateField()                             *//************************************************************************/OGRErr OGRShapeLayer::CreateField( OGRFieldDefn *poField, int bApproxOK ){    CPLAssert( NULL != poField );    int         iNewField;    if( GetFeatureCount(TRUE) != 0 )    {        CPLError( CE_Failure, CPLE_NotSupported,                  "Can't create fields on a Shapefile layer with features.\n");        return OGRERR_FAILURE;    }    if( !bUpdateAccess )    {        CPLError( CE_Failure, CPLE_NotSupported,                  "Can't create fields on a read-only shapefile layer.\n");        return OGRERR_FAILURE;    }/* -------------------------------------------------------------------- *//*      Normalize field name                                            *//* -------------------------------------------------------------------- */            char * pszNewFieldName = NULL;    size_t nNameSize = strlen( poField->GetNameRef() );    pszNewFieldName = CPLScanString( poField->GetNameRef(),                                     nNameSize, TRUE, TRUE);    if( !EQUAL(poField->GetNameRef(),pszNewFieldName) )        CPLDebug( "Shape", "Normalized field name: '%s' to '%s'",                   poField->GetNameRef(),                  pszNewFieldName );    // Set field name with normalized value    poField->SetName( pszNewFieldName );    CPLFree( pszNewFieldName );/* -------------------------------------------------------------------- *//*      Add field to layer                                              *//* -------------------------------------------------------------------- */    if( poField->GetType() == OFTInteger )    {        if( poField->GetWidth() == 0 )            iNewField =                DBFAddField( hDBF, poField->GetNameRef(), FTInteger, 11, 0 );        else            iNewField = DBFAddField( hDBF, poField->GetNameRef(), FTInteger,                                     poField->GetWidth(), 0 );        if( iNewField != -1 )            poFeatureDefn->AddFieldDefn( poField );    }    else if( poField->GetType() == OFTReal )    {        if( poField->GetWidth() == 0 )            iNewField =                DBFAddField( hDBF, poField->GetNameRef(), FTDouble, 24, 15 );        else            iNewField =                DBFAddField( hDBF, poField->GetNameRef(), FTDouble,                             poField->GetWidth(), poField->GetPrecision() );        if( iNewField != -1 )            poFeatureDefn->AddFieldDefn( poField );    }    else if( poField->GetType() == OFTString )    {        if( poField->GetWidth() < 1 )            iNewField =                DBFAddField( hDBF, poField->GetNameRef(), FTString, 80, 0 );        else            iNewField = DBFAddField( hDBF, poField->GetNameRef(), FTString,                                      poField->GetWidth(), 0 );        if( iNewField != -1 )            poFeatureDefn->AddFieldDefn( poField );    }    else if( poField->GetType() == OFTDate )    {        iNewField =            DBFAddNativeFieldType( hDBF, poField->GetNameRef(), 'D', 8, 0 );        if( iNewField != -1 )            poFeatureDefn->AddFieldDefn( poField );    }    else if( poField->GetType() == OFTDateTime )    {        CPLError( CE_Warning, CPLE_NotSupported,                  "Field %s create as date field, though DateTime requested.\n",                  poField->GetNameRef() );        iNewField =            DBFAddNativeFieldType( hDBF, poField->GetNameRef(), 'D', 8, 0 );        if( iNewField != -1 )            poFeatureDefn->AddFieldDefn( poField );    }    else    {        CPLError( CE_Failure, CPLE_NotSupported,                  "Can't create fields of type %s on shapefile layers.\n",                  OGRFieldDefn::GetFieldTypeName(poField->GetType()) );        return OGRERR_FAILURE;    }    if( iNewField != -1 )    {        return OGRERR_NONE;    }    else            {        CPLError( CE_Failure, CPLE_AppDefined,                  "Can't create field %s in Shape DBF file, reason unknown.\n",                  poField->GetNameRef() );        return OGRERR_FAILURE;    }}/************************************************************************//*                           GetSpatialRef()                            *//************************************************************************/

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合天天综合狠狠| 不卡av电影在线播放| 成人午夜激情在线| 欧美一区二区三区思思人| 亚洲色图一区二区三区| 久久电影网电视剧免费观看| 色哟哟国产精品| 国产女人水真多18毛片18精品视频 | 精品乱人伦小说| ...中文天堂在线一区| 国内国产精品久久| 在线成人午夜影院| 亚洲精品你懂的| 99视频一区二区| 亚洲精品一区二区三区福利| 五月婷婷激情综合网| 色综合久久久久| 中文字幕一区二区三区不卡| 国产一区二区在线电影| 欧美体内she精视频| 亚洲免费观看视频| av在线不卡观看免费观看| 久久久一区二区三区| 久久国产精品99精品国产| 67194成人在线观看| 一区二区三区色| 成人国产精品免费观看| 日韩免费看的电影| 国产精品三级电影| 婷婷中文字幕综合| 亚洲已满18点击进入久久| av电影在线不卡| 国产日韩欧美高清| 国产精品久久久久影院| 欧美裸体一区二区三区| 91老师片黄在线观看| 国产亚洲一本大道中文在线| 国产乱子伦一区二区三区国色天香| 91精品国产综合久久久久久久久久| 婷婷六月综合网| 在线观看亚洲a| 一区二区三区四区不卡视频| 97精品国产露脸对白| 亚洲视频在线一区观看| 色综合天天综合色综合av| 一区二区三区免费观看| 91国在线观看| 五月天激情综合| 91精品国产麻豆国产自产在线 | 国产亚洲1区2区3区| 粉嫩aⅴ一区二区三区四区五区 | 欧美一区二区三区视频在线观看| 男女男精品视频网| 精品国产在天天线2019| 国产电影一区在线| 国产精品天天摸av网| 99这里都是精品| 国产精品美女久久久久av爽李琼 | 五月天激情综合| 欧美三级中文字| 亚洲成人av免费| 欧美片网站yy| 日韩影院精彩在线| 日韩免费在线观看| 亚洲h精品动漫在线观看| 日韩一级黄色大片| 久久国产夜色精品鲁鲁99| 日韩欧美精品三级| 激情伊人五月天久久综合| 久久尤物电影视频在线观看| 国产成人av电影在线播放| 国产精品美女久久久久av爽李琼 | 中文字幕在线观看不卡视频| 在线亚洲欧美专区二区| 亚洲高清不卡在线| 日韩一区二区三区三四区视频在线观看| 免费看黄色91| 久久久国产午夜精品 | 亚洲一区二区三区影院| 在线播放国产精品二区一二区四区 | 国产精品香蕉一区二区三区| 国产拍欧美日韩视频二区| 丁香六月久久综合狠狠色| 国产精品国产三级国产专播品爱网| 91视频在线看| 亚洲va在线va天堂| 久久综合色婷婷| av午夜一区麻豆| 亚洲成人福利片| 欧美xingq一区二区| 国产精品一区二区黑丝| 亚洲男人的天堂av| 91精品国产综合久久久久久| 国产精品一二三区| 亚洲日本青草视频在线怡红院| 日本道在线观看一区二区| 亚洲国产一区二区在线播放| 国产婷婷色一区二区三区| 97国产精品videossex| 午夜电影一区二区| 国产亚洲视频系列| 欧美视频一区在线| 国产精品一区二区久久精品爱涩| 亚洲乱码中文字幕综合| 欧美第一区第二区| 色综合久久天天综合网| 韩国女主播一区二区三区| 亚洲乱码国产乱码精品精可以看 | 成人av在线资源| 天天色综合成人网| 久久综合av免费| 91精品福利视频| 国产成人精品在线看| 国产成人av在线影院| 日韩高清国产一区在线| 国产无一区二区| 欧美一二三区在线| 成人aa视频在线观看| 久久97超碰色| 亚洲成人资源在线| 国产精品理论片| 欧美一级一区二区| 91久久线看在观草草青青| 国产在线视视频有精品| 亚洲免费观看在线观看| 亚洲精品在线电影| 欧美军同video69gay| jlzzjlzz亚洲日本少妇| 久久综合综合久久综合| 中文字幕综合网| 久久久午夜精品| 欧美一级高清片在线观看| 成人激情小说乱人伦| 激情国产一区二区| 天天免费综合色| 亚洲欧洲色图综合| 国产色婷婷亚洲99精品小说| 91精品黄色片免费大全| 一本色道亚洲精品aⅴ| 国产成人激情av| 美女网站在线免费欧美精品| 一级精品视频在线观看宜春院| 国产欧美一区二区三区鸳鸯浴 | 国产精品小仙女| 久久97超碰国产精品超碰| 五月激情综合网| 亚洲综合图片区| 一区免费观看视频| 欧美激情一区二区三区| 欧美刺激午夜性久久久久久久| 欧美日本一区二区| 国产精品77777竹菊影视小说| 美国欧美日韩国产在线播放| 午夜精品福利一区二区三区av| 亚洲天堂av老司机| 国产精品另类一区| 中文字幕 久热精品 视频在线| 久久嫩草精品久久久精品一| 日韩免费高清视频| 欧美一区二区三区四区五区| 欧美久久婷婷综合色| 欧美天堂一区二区三区| 91福利在线免费观看| 色乱码一区二区三区88| av在线不卡观看免费观看| 成人听书哪个软件好| 大美女一区二区三区| 国产高清不卡二三区| 国产成人精品三级| 国产精品456| 国产真实精品久久二三区| 国产一区二区在线影院| 国精产品一区一区三区mba桃花| 精彩视频一区二区| 精品一二三四区| 国产一区二区三区视频在线播放| 国产成人免费网站| 国产精品69久久久久水密桃| a在线欧美一区| 97国产一区二区| 欧美日韩在线播放一区| 欧美精品一二三| 精品va天堂亚洲国产| 国产午夜亚洲精品理论片色戒| 1区2区3区精品视频| 亚洲男人电影天堂| 亚洲一区二区三区精品在线| 亚洲一区二区在线视频| 一区二区三区在线视频播放| 亚洲精品国产一区二区三区四区在线| 亚洲卡通动漫在线| 日日夜夜免费精品视频| 国模冰冰炮一区二区| 成人99免费视频| 亚洲欧美日韩在线| 亚洲午夜一二三区视频| 久99久精品视频免费观看| 国产露脸91国语对白| 色呦呦国产精品| 欧美日韩一级二级|