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

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

?? ogrmemlayer.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
字號:
/****************************************************************************** * $Id: ogrmemlayer.cpp 10646 2007-01-18 02:38:10Z warmerdam $ * * Project:  OpenGIS Simple Features Reference Implementation * Purpose:  Implements OGRMemLayer class. * Author:   Frank Warmerdam, warmerdam@pobox.com * ****************************************************************************** * Copyright (c) 2003, Frank Warmerdam <warmerdam@pobox.com> * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. ****************************************************************************/#include "ogr_mem.h"#include "cpl_conv.h"CPL_CVSID("$Id: ogrmemlayer.cpp 10646 2007-01-18 02:38:10Z warmerdam $");/************************************************************************//*                            OGRMemLayer()                             *//************************************************************************/OGRMemLayer::OGRMemLayer( const char * pszName, OGRSpatialReference *poSRSIn,                           OGRwkbGeometryType eReqType ){    if( poSRSIn == NULL )        poSRS = NULL;    else        poSRS = poSRSIn->Clone();        iNextReadFID = 0;    iNextCreateFID = 0;    nFeatureCount = 0;    nMaxFeatureCount = 0;    papoFeatures = NULL;    poFeatureDefn = new OGRFeatureDefn( pszName );    poFeatureDefn->SetGeomType( eReqType );    poFeatureDefn->Reference();}/************************************************************************//*                           ~OGRMemLayer()                           *//************************************************************************/OGRMemLayer::~OGRMemLayer(){    if( m_nFeaturesRead > 0 && poFeatureDefn != NULL )    {        CPLDebug( "Mem", "%d features read on layer '%s'.",                  (int) m_nFeaturesRead,                   poFeatureDefn->GetName() );    }    for( int i = 0; i < nMaxFeatureCount; i++ )    {        if( papoFeatures[i] != NULL )            delete papoFeatures[i];    }    CPLFree( papoFeatures );    if( poFeatureDefn )        poFeatureDefn->Release();    if( poSRS )        poSRS->Release();}/************************************************************************//*                            ResetReading()                            *//************************************************************************/void OGRMemLayer::ResetReading(){    iNextReadFID = 0;}/************************************************************************//*                           GetNextFeature()                           *//************************************************************************/OGRFeature *OGRMemLayer::GetNextFeature(){    while( iNextReadFID < nMaxFeatureCount )    {        OGRFeature *poFeature = papoFeatures[iNextReadFID++];        if( poFeature == NULL )            continue;        if( (m_poFilterGeom == NULL             || FilterGeometry( poFeature->GetGeometryRef() ) )            && (m_poAttrQuery == NULL                || m_poAttrQuery->Evaluate( poFeature ) ) )        {            m_nFeaturesRead++;            return poFeature->Clone();        }    }    return NULL;}/************************************************************************//*                           SetNextByIndex()                           *//*                                                                      *//*      If we already have an FID list, we can easily resposition       *//*      ourselves in it.                                                *//************************************************************************/OGRErr OGRMemLayer::SetNextByIndex( long nIndex ){    if( m_poFilterGeom != NULL || m_poAttrQuery != NULL )        return OGRLayer::SetNextByIndex( nIndex );    iNextReadFID = nIndex;    return OGRERR_NONE;}/************************************************************************//*                             GetFeature()                             *//************************************************************************/OGRFeature *OGRMemLayer::GetFeature( long nFeatureId ){    if( nFeatureId < 0 || nFeatureId >= nMaxFeatureCount )        return NULL;    else if( papoFeatures[nFeatureId] == NULL )        return NULL;    else        return papoFeatures[nFeatureId]->Clone();}/************************************************************************//*                             SetFeature()                             *//************************************************************************/OGRErr OGRMemLayer::SetFeature( OGRFeature *poFeature ){    if( poFeature == NULL )        return OGRERR_FAILURE;    if( poFeature->GetFID() == OGRNullFID )    {        while( iNextCreateFID < nMaxFeatureCount                && papoFeatures[iNextCreateFID] != NULL )            iNextCreateFID++;        poFeature->SetFID( iNextCreateFID++ );    }    if( poFeature->GetFID() >= nMaxFeatureCount )    {        int nNewCount = MAX(2*nMaxFeatureCount+10, poFeature->GetFID() + 1 );        papoFeatures = (OGRFeature **)             CPLRealloc( papoFeatures, sizeof(OGRFeature *) * nNewCount);        memset( papoFeatures + nMaxFeatureCount, 0,                 sizeof(OGRFeature *) * (nNewCount - nMaxFeatureCount) );        nMaxFeatureCount = nNewCount;    }    if( papoFeatures[poFeature->GetFID()] != NULL )    {        delete papoFeatures[poFeature->GetFID()];        papoFeatures[poFeature->GetFID()] = NULL;        nFeatureCount--;    }    papoFeatures[poFeature->GetFID()] = poFeature->Clone();    nFeatureCount++;    return OGRERR_NONE;}/************************************************************************//*                           CreateFeature()                            *//************************************************************************/OGRErr OGRMemLayer::CreateFeature( OGRFeature *poFeature ){    if( poFeature->GetFID() != OGRNullFID         && poFeature->GetFID() >= 0        && poFeature->GetFID() < nMaxFeatureCount )    {        if( papoFeatures[poFeature->GetFID()] != NULL )            poFeature->SetFID( OGRNullFID );    }    if( poFeature->GetFID() > 10000000 )        poFeature->SetFID( OGRNullFID );    return SetFeature( poFeature );}/************************************************************************//*                           DeleteFeature()                            *//************************************************************************/OGRErr OGRMemLayer::DeleteFeature( long nFID ){    if( nFID < 0 || nFID >= nMaxFeatureCount         || papoFeatures[nFID] == NULL )    {        return OGRERR_FAILURE;    }    else     {        delete papoFeatures[nFID];        papoFeatures[nFID] = NULL;        nFeatureCount--;        return OGRERR_NONE;    }}/************************************************************************//*                          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 OGRMemLayer::GetFeatureCount( int bForce ){    if( m_poFilterGeom != NULL || m_poAttrQuery != NULL )        return OGRLayer::GetFeatureCount( bForce );    else        return nFeatureCount;}/************************************************************************//*                             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 OGRMemLayer::GetExtent (OGREnvelope *psExtent, int bForce){    return OGRLayer::GetExtent( psExtent, bForce );}/************************************************************************//*                           TestCapability()                           *//************************************************************************/int OGRMemLayer::TestCapability( const char * pszCap ){    if( EQUAL(pszCap,OLCRandomRead) )        return TRUE;    else if( EQUAL(pszCap,OLCSequentialWrite)              || EQUAL(pszCap,OLCRandomWrite) )        return TRUE;    else if( EQUAL(pszCap,OLCFastFeatureCount) )        return m_poFilterGeom == NULL;    else if( EQUAL(pszCap,OLCFastSpatialFilter) )        return FALSE;    else if( EQUAL(pszCap,OLCFastGetExtent) )        return TRUE;    else if( EQUAL(pszCap,OLCDeleteFeature) )        return TRUE;    else if( EQUAL(pszCap,OLCCreateField) )        return TRUE;    else if( EQUAL(pszCap,OLCFastSetNextByIndex) )        return m_poFilterGeom != NULL && m_poAttrQuery == NULL;    else         return FALSE;}/************************************************************************//*                            CreateField()                             *//************************************************************************/OGRErr OGRMemLayer::CreateField( OGRFieldDefn *poField, int bApproxOK ){/* -------------------------------------------------------------------- *//*      simple case, no features exist yet.                             *//* -------------------------------------------------------------------- */    if( nFeatureCount == 0 )    {        poFeatureDefn->AddFieldDefn( poField );        return OGRERR_NONE;    }/* -------------------------------------------------------------------- *//*      Add field definition and setup remap definition.                *//* -------------------------------------------------------------------- */    int  *panRemap;    int   i;    poFeatureDefn->AddFieldDefn( poField );    panRemap = (int *) CPLMalloc(sizeof(int) * poFeatureDefn->GetFieldCount());    for( i = 0; i < poFeatureDefn->GetFieldCount(); i++ )    {        if( i < poFeatureDefn->GetFieldCount() - 1 )            panRemap[i] = i;        else            panRemap[i] = -1;    }/* -------------------------------------------------------------------- *//*      Remap all the internal features.  Hopefully there aren't any    *//*      external features referring to our OGRFeatureDefn!              *//* -------------------------------------------------------------------- */    for( i = 0; i < nMaxFeatureCount; i++ )    {        if( papoFeatures[i] != NULL )            papoFeatures[i]->RemapFields( NULL, panRemap );    }    return OGRERR_NONE;}/************************************************************************//*                           GetSpatialRef()                            *//************************************************************************/OGRSpatialReference *OGRMemLayer::GetSpatialRef(){    return poSRS;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲小说欧美激情另类| 国产在线国偷精品免费看| 欧美精品一区二区不卡| 91免费国产在线| 美女高潮久久久| 亚洲美女区一区| 国产精品嫩草99a| 久久蜜臀精品av| 制服.丝袜.亚洲.中文.综合| 色哟哟欧美精品| 成人午夜电影小说| 精品在线一区二区| 婷婷成人综合网| 一区二区视频免费在线观看| 国产精品拍天天在线| 精品欧美一区二区久久| 欧美一区二区美女| 欧洲精品一区二区三区在线观看| 成人黄色av电影| 国产福利一区在线观看| 国产在线一区二区综合免费视频| 香港成人在线视频| 亚洲国产人成综合网站| 亚洲高清中文字幕| 亚洲综合色噜噜狠狠| 亚洲欧洲精品成人久久奇米网| 国产亚洲精品aa午夜观看| 欧美v国产在线一区二区三区| 欧美日韩亚洲综合| 欧美午夜精品一区二区三区| 色哟哟一区二区在线观看| 91色.com| 91九色02白丝porn| 色嗨嗨av一区二区三区| 在线观看www91| 欧美三级中文字| 欧美日韩国产综合久久| 欧美人与禽zozo性伦| 欧美另类一区二区三区| 777久久久精品| 日韩无一区二区| 精品少妇一区二区三区免费观看 | 亚洲免费在线视频一区 二区| 国产色爱av资源综合区| 中文字幕第一区二区| 国产精品视频第一区| 中文字幕一区二区5566日韩| 国产精品成人在线观看| 亚洲精品视频在线观看网站| 亚洲不卡在线观看| 免费国产亚洲视频| 国产伦精品一区二区三区视频青涩 | 亚洲a一区二区| 视频一区在线视频| 麻豆精品一区二区av白丝在线| 精品一区二区三区不卡| 国产福利一区在线观看| 91在线看国产| 7777精品伊人久久久大香线蕉的 | 91一区一区三区| 91久久精品网| 日韩欧美一区二区三区在线| 久久久久久电影| 亚洲精品第一国产综合野| 午夜精品福利一区二区三区蜜桃| 久久99精品国产.久久久久| 国产东北露脸精品视频| 一本在线高清不卡dvd| 91精品国产色综合久久不卡蜜臀| 国产亚洲综合av| 亚洲综合另类小说| 国产最新精品精品你懂的| 成a人片亚洲日本久久| 欧美午夜电影在线播放| 久久亚洲综合色一区二区三区| 国产精品久久久久久亚洲毛片| 午夜一区二区三区在线观看| 韩国av一区二区三区在线观看| 色综合久久久久网| 日韩一区二区三| 亚洲欧美一区二区久久| 久久国产精品72免费观看| 97精品久久久午夜一区二区三区| 69堂国产成人免费视频| 国产精品久久久久一区二区三区| 日韩在线a电影| 91亚洲精品久久久蜜桃网站| 7777精品伊人久久久大香线蕉超级流畅| 久久久午夜电影| 五月天丁香久久| 成人天堂资源www在线| 91精品国产品国语在线不卡| 国产精品传媒入口麻豆| 激情综合色播激情啊| 欧美怡红院视频| 国产精品乱码人人做人人爱| 精品一区二区三区在线观看| 在线观看日韩精品| 国产精品视频第一区| 精彩视频一区二区| 欧美日韩国产高清一区二区| 亚洲欧美日韩电影| 国产精品亚洲第一| 欧美成人免费网站| 午夜影院在线观看欧美| 色屁屁一区二区| 欧美国产一区视频在线观看| 麻豆极品一区二区三区| 欧美日韩一区二区三区四区| 亚洲三级在线观看| 国产91丝袜在线18| 26uuu亚洲| 久久99精品国产麻豆不卡| 6080午夜不卡| 午夜精品久久久久影视| 色哟哟一区二区| 中文字幕一区av| 不卡av电影在线播放| 国产农村妇女毛片精品久久麻豆 | 精品一区二区精品| 欧美精品第1页| 五月天欧美精品| 欧美色图第一页| 亚洲丶国产丶欧美一区二区三区| 色综合久久中文综合久久97| 亚洲欧美日韩国产一区二区三区| 成人免费观看男女羞羞视频| 中文子幕无线码一区tr| 国产激情视频一区二区三区欧美 | 91精品国产91久久久久久一区二区 | 中文字幕一区二区视频| 成人免费看的视频| 国产精品国产三级国产普通话99| 成人丝袜18视频在线观看| 国产精品日日摸夜夜摸av| 不卡视频一二三| 一区二区三区欧美在线观看| 91黄色免费看| 天天影视色香欲综合网老头| 欧美日韩黄色影视| 日韩激情中文字幕| 日韩欧美国产麻豆| 美女被吸乳得到大胸91| 亚洲精品在线一区二区| 国产福利一区在线| 中文字幕欧美一| 在线观看视频一区二区| 五月天一区二区| 欧美精品一区二区三区在线播放| 加勒比av一区二区| 国产精品午夜在线观看| 在线看国产日韩| 五月激情综合色| 337p日本欧洲亚洲大胆精品| 成人综合激情网| 一区二区免费视频| 欧美一级理论片| 国产激情一区二区三区| 亚洲精品视频免费看| 欧美精品免费视频| 久99久精品视频免费观看| 国产欧美一区二区三区在线老狼| 91在线播放网址| 视频一区视频二区在线观看| 欧美精品一区二区久久婷婷| av一区二区三区| 丝袜美腿亚洲综合| 欧美激情在线观看视频免费| 色呦呦国产精品| 久久99精品久久久久久国产越南 | 亚洲资源中文字幕| 欧美成人精品3d动漫h| 成人不卡免费av| 亚洲成人免费电影| 国产欧美一区在线| 欧美日韩和欧美的一区二区| 国产成人精品一区二| 香蕉成人啪国产精品视频综合网| 国产亚洲欧美日韩在线一区| 欧美色中文字幕| 成人美女视频在线看| 五月婷婷综合网| 中文字幕日韩av资源站| 日韩欧美在线观看一区二区三区| a亚洲天堂av| 激情另类小说区图片区视频区| 亚洲欧美偷拍卡通变态| 26uuu久久综合| 欧美裸体一区二区三区| 成人动漫视频在线| 久久av中文字幕片| 亚洲一二三级电影| 国产精品免费视频网站| 精品国产免费一区二区三区香蕉| 欧亚洲嫩模精品一区三区| 成人av在线网| 国产一区二区久久| 日韩成人一区二区三区在线观看| 亚洲免费资源在线播放| 国产精品网站一区|