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

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

?? ogrntfdatasource.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/****************************************************************************** * $Id: ogrntfdatasource.cpp 10646 2007-01-18 02:38:10Z warmerdam $ * * Project:  UK NTF Reader * Purpose:  Implements OGRNTFDataSource class * Author:   Frank Warmerdam, warmerdam@pobox.com * ****************************************************************************** * Copyright (c) 1999, Frank Warmerdam * * 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 "ntf.h"#include "cpl_conv.h"#include "cpl_string.h"CPL_CVSID("$Id: ogrntfdatasource.cpp 10646 2007-01-18 02:38:10Z warmerdam $");/************************************************************************//*                          OGRNTFDataSource()                          *//************************************************************************/OGRNTFDataSource::OGRNTFDataSource(){    nLayers = 0;    papoLayers = NULL;    nNTFFileCount = 0;    papoNTFFileReader = NULL;    pszName = NULL;    iCurrentReader = -1;    iCurrentFC = 0;    nFCCount = 0;    papszFCNum = NULL;    papszFCName = NULL;    poFCLayer = NULL;    papszOptions = NULL;    poSpatialRef = new OGRSpatialReference( "PROJCS[\"OSGB 1936 / British National Grid\",GEOGCS[\"OSGB 1936\",DATUM[\"OSGB_1936\",SPHEROID[\"Airy 1830\",6377563.396,299.3249646,AUTHORITY[\"EPSG\",\"7001\"]],AUTHORITY[\"EPSG\",\"6277\"]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",\"8901\"]],UNIT[\"degree\",0.0174532925199433],AUTHORITY[\"EPSG\",\"4277\"]],PROJECTION[\"Transverse_Mercator\"],PARAMETER[\"latitude_of_origin\",49],PARAMETER[\"central_meridian\",-2],PARAMETER[\"scale_factor\",0.999601272],PARAMETER[\"false_easting\",400000],PARAMETER[\"false_northing\",-100000],UNIT[\"metre\",1,AUTHORITY[\"EPSG\",\"9001\"]],AUTHORITY[\"EPSG\",\"27700\"]]" );/* -------------------------------------------------------------------- *//*      Allow initialization of options from the environment.           *//* -------------------------------------------------------------------- */    if( getenv("OGR_NTF_OPTIONS") != NULL )    {        papszOptions =             CSLTokenizeStringComplex( getenv("OGR_NTF_OPTIONS"), ",",                                      FALSE, FALSE );    }}/************************************************************************//*                         ~OGRNTFDataSource()                          *//************************************************************************/OGRNTFDataSource::~OGRNTFDataSource(){    int         i;    for( i = 0; i < nNTFFileCount; i++ )        delete papoNTFFileReader[i];    CPLFree( papoNTFFileReader );    for( i = 0; i < nLayers; i++ )        delete papoLayers[i];    if( poFCLayer != NULL )        delete poFCLayer;        CPLFree( papoLayers );    CPLFree( pszName );    CSLDestroy( papszOptions );    CSLDestroy( papszFCNum );    CSLDestroy( papszFCName );    if( poSpatialRef )        poSpatialRef->Release();}/************************************************************************//*                           TestCapability()                           *//************************************************************************/int OGRNTFDataSource::TestCapability( const char * ){    return FALSE;}/************************************************************************//*                           GetNamedLayer()                            *//************************************************************************/OGRNTFLayer * OGRNTFDataSource::GetNamedLayer( const char * pszName ){    for( int i = 0; i < nLayers; i++ )    {        if( EQUAL(papoLayers[i]->GetLayerDefn()->GetName(),pszName) )            return (OGRNTFLayer *) papoLayers[i];    }    return NULL;}/************************************************************************//*                              AddLayer()                              *//************************************************************************/void OGRNTFDataSource::AddLayer( OGRLayer * poNewLayer ){    papoLayers = (OGRLayer **)        CPLRealloc( papoLayers, sizeof(void*) * ++nLayers );        papoLayers[nLayers-1] = poNewLayer;}/************************************************************************//*                              GetLayer()                              *//************************************************************************/OGRLayer *OGRNTFDataSource::GetLayer( int iLayer ){    if( iLayer < 0 || iLayer > nLayers )        return NULL;    else if( iLayer == nLayers )        return poFCLayer;    else        return papoLayers[iLayer];}/************************************************************************//*                           GetLayerCount()                            *//************************************************************************/int OGRNTFDataSource::GetLayerCount(){    if( poFCLayer == NULL )        return nLayers;    else        return nLayers + 1;}/************************************************************************//*                                Open()                                *//************************************************************************/int OGRNTFDataSource::Open( const char * pszFilename, int bTestOpen,                            char ** papszLimitedFileList ){    VSIStatBuf      stat;    char            **papszFileList = NULL;    pszName = CPLStrdup( pszFilename );/* -------------------------------------------------------------------- *//*      Is the given path a directory or a regular file?                *//* -------------------------------------------------------------------- */    if( CPLStat( pszFilename, &stat ) != 0         || (!VSI_ISDIR(stat.st_mode) && !VSI_ISREG(stat.st_mode)) )    {        if( !bTestOpen )            CPLError( CE_Failure, CPLE_AppDefined,                   "%s is neither a file or directory, NTF access failed.\n",                      pszFilename );        return FALSE;    }    /* -------------------------------------------------------------------- *//*      Build a list of filenames we figure are NTF files.              *//* -------------------------------------------------------------------- */    if( VSI_ISREG(stat.st_mode) )    {        papszFileList = CSLAddString( NULL, pszFilename );    }    else    {        char      **candidateFileList = CPLReadDir( pszFilename );        int         i;        for( i = 0;              candidateFileList != NULL && candidateFileList[i] != NULL;              i++ )         {            if( papszLimitedFileList != NULL                && CSLFindString(papszLimitedFileList,                                 candidateFileList[i]) == -1 )            {                continue;            }                        if( strlen(candidateFileList[i]) > 4              && EQUALN(candidateFileList[i] + strlen(candidateFileList[i])-4,                       ".ntf",4) )            {                char       fullFilename[2048];                sprintf( fullFilename, "%s%c%s",                          pszFilename,#ifdef WIN32                         '\\',#else                         '/',#endif                         candidateFileList[i] );                papszFileList = CSLAddString( papszFileList, fullFilename );            }        }        CSLDestroy( candidateFileList );        if( CSLCount(papszFileList) == 0 )        {            if( !bTestOpen )                CPLError( CE_Failure, CPLE_OpenFailed,                          "No candidate NTF files (.ntf) found in\n"                          "directory: %s",                          pszFilename );            return FALSE;        }    }/* -------------------------------------------------------------------- *//*      Loop over all these files trying to open them.  In testopen     *//*      mode we first read the first 80 characters, to verify that      *//*      it looks like an NTF file.  Note that we don't keep the file    *//*      open ... we don't want to occupy alot of file handles when      *//*      handling a whole directory.                                     *//* -------------------------------------------------------------------- */    int         i;    papoNTFFileReader = (NTFFileReader **)        CPLCalloc(sizeof(void*), CSLCount(papszFileList));        for( i = 0; papszFileList[i] != NULL; i++ )    {        if( bTestOpen )        {            char        szHeader[80];            FILE        *fp;            int         j;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美视频在线一区| 成人黄页毛片网站| 欧美一区二区私人影院日本| 午夜亚洲福利老司机| 欧美视频完全免费看| 手机精品视频在线观看| 这里只有精品99re| 麻豆精品一二三| 久久久久高清精品| 99vv1com这只有精品| 亚洲一本大道在线| 日韩一区二区免费电影| 国产乱码精品一区二区三| 国产欧美精品一区二区色综合朱莉| 国产v综合v亚洲欧| √…a在线天堂一区| 欧美性色欧美a在线播放| 日韩电影在线一区| 国产性色一区二区| 91福利视频在线| 美女网站在线免费欧美精品| 精品对白一区国产伦| av电影在线不卡| 亚洲成人av电影| 久久久精品综合| 欧美综合一区二区三区| 麻豆国产精品官网| 国产精品久久久久久久久图文区| 欧美视频中文字幕| 国产一区二区中文字幕| 亚洲最色的网站| 日韩一级二级三级| 99视频精品在线| 免费观看30秒视频久久| 中文字幕日韩一区| 日韩欧美中文字幕制服| 91视频xxxx| 韩国视频一区二区| 亚洲黄色性网站| 国产午夜精品一区二区三区四区| 在线看不卡av| 粉嫩aⅴ一区二区三区四区 | 国产婷婷色一区二区三区四区| 成人永久看片免费视频天堂| 婷婷开心激情综合| 国产精品不卡一区二区三区| 日韩欧美电影一区| 欧美午夜精品免费| 成人午夜精品在线| 精品制服美女丁香| 香蕉av福利精品导航| 国产精品国产三级国产普通话三级| 69av一区二区三区| 色综合咪咪久久| 国产成人在线观看| 免费成人在线网站| 亚洲国产精品久久久久秋霞影院| 国产精品第五页| 国产欧美日韩在线| 欧美变态tickling挠脚心| 欧美日韩午夜精品| av电影在线观看完整版一区二区| 亚洲综合在线视频| 国产精品丝袜久久久久久app| 日韩欧美中文字幕一区| 欧美日韩精品一区二区在线播放| 91在线高清观看| 国产精品一线二线三线| 免费成人av在线| 午夜亚洲国产au精品一区二区| 亚洲精品视频在线| 国产精品成人网| 欧美国产一区视频在线观看| 久久亚洲精品国产精品紫薇| 欧美精品一区二| 日韩一区二区在线看| 91麻豆精品91久久久久同性| 91精品国产综合久久精品麻豆| 欧美日韩国产综合久久| 欧美伦理影视网| 欧美丰满少妇xxxbbb| 3d动漫精品啪啪一区二区竹菊| 欧美日韩免费视频| 欧美高清视频在线高清观看mv色露露十八| 色国产综合视频| 欧美日韩一区二区电影| 欧美日产国产精品| 91精品国产丝袜白色高跟鞋| 日韩精品中文字幕一区二区三区| 精品国产一区二区精华| 久久美女艺术照精彩视频福利播放| 久久久久久久久久久久久女国产乱| 国产三级欧美三级日产三级99| 亚洲国产精品av| 亚洲欧美综合色| 亚洲一二三区在线观看| 日本麻豆一区二区三区视频| 激情另类小说区图片区视频区| 国内精品写真在线观看| www.成人在线| 欧美视频在线一区二区三区| 日韩一级黄色大片| 国产亚洲精品中文字幕| 国产精品高潮呻吟久久| 亚洲综合区在线| 日日摸夜夜添夜夜添亚洲女人| 久久福利视频一区二区| 国产ts人妖一区二区| 91看片淫黄大片一级在线观看| 欧美日韩视频在线观看一区二区三区| 91麻豆精品国产自产在线 | 欧美乱熟臀69xxxxxx| 日韩亚洲欧美成人一区| 久久精品一区二区三区不卡牛牛| 亚洲欧洲精品一区二区精品久久久 | 欧美精品 日韩| 欧美—级在线免费片| 亚洲一区二区影院| 黄页网站大全一区二区| 93久久精品日日躁夜夜躁欧美| 91精品在线一区二区| 国产精品三级久久久久三级| 日韩高清欧美激情| 成人性视频免费网站| 欧美精品第1页| 国产精品素人一区二区| 人禽交欧美网站| va亚洲va日韩不卡在线观看| 91麻豆精品国产| 亚洲欧美日韩一区二区 | 高清成人免费视频| 678五月天丁香亚洲综合网| 中文成人av在线| 日本麻豆一区二区三区视频| 色婷婷综合在线| 久久亚洲精品小早川怜子| 亚洲成a人片在线观看中文| 成人免费三级在线| 欧美一区二区二区| 亚洲欧美日韩成人高清在线一区| 久久99国产精品成人| 欧美日韩黄色影视| 亚洲另类在线视频| 成人精品视频.| 精品噜噜噜噜久久久久久久久试看| 亚洲一区二区三区四区五区黄| 国产乱码精品一区二区三区av | 久久久久久久久久电影| 丝袜a∨在线一区二区三区不卡| 97久久超碰精品国产| 久久久精品免费免费| 免费成人结看片| 9191国产精品| 亚洲bt欧美bt精品777| 91免费观看国产| 亚洲欧洲无码一区二区三区| 国产成人在线免费观看| 精品成人a区在线观看| 免费不卡在线观看| 日韩一区二区三区视频在线| 石原莉奈在线亚洲二区| 在线视频你懂得一区二区三区| 国产精品久久久久久久久晋中| 国产精品一区在线观看乱码| 精品少妇一区二区三区日产乱码| 日韩成人精品在线| 欧美精品色一区二区三区| 亚洲最大成人综合| 欧美吻胸吃奶大尺度电影| 亚洲黄色在线视频| 欧美午夜精品一区二区蜜桃| 亚洲一区在线看| 欧美日韩免费在线视频| 亚洲国产综合在线| 欧美日韩高清在线播放| 日韩影院免费视频| 欧美精品 国产精品| 美脚の诱脚舐め脚责91| 久久这里只有精品6| 国产麻豆一精品一av一免费 | 国产黄色精品视频| 国产日韩欧美激情| 成人动漫中文字幕| 亚洲欧美另类小说视频| 91久久人澡人人添人人爽欧美| 亚洲一区二区视频在线观看| 欧美天天综合网| 日韩av中文在线观看| 精品日本一线二线三线不卡| 国产精品88888| 亚洲色图欧洲色图| 欧美亚洲图片小说| 亚洲午夜精品在线| 日韩一级高清毛片| 国产成人在线视频网站| 亚洲男人的天堂在线aⅴ视频 | 91小视频免费看| 一区二区三区日韩欧美精品| 欧美日韩亚州综合| 激情综合网av|