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

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

?? ntf_estlayers.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
/****************************************************************************** * $Id: ntf_estlayers.cpp 10646 2007-01-18 02:38:10Z warmerdam $ * * Project:  NTF Translator * Purpose:  NTFFileReader methods related to establishing the schemas *           of features that could occur in this product and the functions *           for actually performing the NTFRecord to OGRFeature conversion. * 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 <stdarg.h>#include "ntf.h"#include "cpl_string.h"CPL_CVSID("$Id: ntf_estlayers.cpp 10646 2007-01-18 02:38:10Z warmerdam $");#define MAX_LINK        5000/************************************************************************//*                         TranslateCodePoint()                         *//*                                                                      *//*      Used for code point, and code point plus.                       *//************************************************************************/static OGRFeature *TranslateCodePoint( NTFFileReader *poReader,                                       OGRNTFLayer *poLayer,                                       NTFRecord **papoGroup ){    if( CSLCount((char **) papoGroup) < 2        || papoGroup[0]->GetType() != NRT_POINTREC        || papoGroup[1]->GetType() != NRT_GEOMETRY )        return NULL;            OGRFeature  *poFeature = new OGRFeature( poLayer->GetLayerDefn() );    // POINT_ID    poFeature->SetField( 0, atoi(papoGroup[0]->GetField( 3, 8 )) );    // Geometry    poFeature->SetGeometryDirectly(poReader->ProcessGeometry(papoGroup[1]));    // Attributes    if( EQUAL(poLayer->GetLayerDefn()->GetName(),"CODE_POINT") )        poReader->ApplyAttributeValues( poFeature, papoGroup,                                        "PC", 1, "PQ", 2, "PR", 3, "TP", 4,                                        "DQ", 5, "RP", 6, "BP", 7, "PD", 8,                                        "MP", 9, "UM", 10, "RV", 11,                                         NULL );    else        poReader->ApplyAttributeValues( poFeature, papoGroup,                                        "PC", 1, "PQ", 2, "PR", 3, "TP", 4,                                        "DQ", 5, "RP", 6, "BP", 7, "PD", 8,                                        "MP", 9, "UM", 10, "RV", 11,                                        "RH", 12, "LH", 13, "CC", 14,                                        "DC", 15, "WC", 16,                                         NULL );    return poFeature;}/************************************************************************//*                       TranslateAddressPoint()                        *//************************************************************************/static OGRFeature *TranslateAddressPoint( NTFFileReader *poReader,                                          OGRNTFLayer *poLayer,                                          NTFRecord **papoGroup ){    if( CSLCount((char **) papoGroup) < 2        || papoGroup[0]->GetType() != NRT_POINTREC        || papoGroup[1]->GetType() != NRT_GEOMETRY )        return NULL;            OGRFeature  *poFeature = new OGRFeature( poLayer->GetLayerDefn() );    // POINT_ID    poFeature->SetField( 0, atoi(papoGroup[0]->GetField( 3, 8 )) );    // CHG_TYPE    poFeature->SetField( 17, papoGroup[0]->GetField( 22, 22 ) );    // CHG_DATE    poFeature->SetField( 18, papoGroup[0]->GetField( 23, 28 ) );    // Geometry    poFeature->SetGeometryDirectly(poReader->ProcessGeometry(papoGroup[1]));    // Attributes    poReader->ApplyAttributeValues( poFeature, papoGroup,                                    "OA", 1, "ON", 2, "DP", 3, "PB", 4,                                    "SB", 5, "BD", 6, "BN", 7, "DR", 8,                                    "TN", 9, "DD", 10, "DL", 11, "PT", 12,                                    "CN", 13, "PC", 14, "SF", 15, "RV", 16,                                    NULL );    return poFeature;}/************************************************************************//*                        TranslateOscarPoint()                         *//*                                                                      *//*      Used for OSCAR Traffic and Asset datasets.                      *//************************************************************************/static OGRFeature *TranslateOscarPoint( NTFFileReader *poReader,                                        OGRNTFLayer *poLayer,                                        NTFRecord **papoGroup ){    if( CSLCount((char **) papoGroup) < 2        || papoGroup[0]->GetType() != NRT_POINTREC        || papoGroup[1]->GetType() != NRT_GEOMETRY )        return NULL;            OGRFeature  *poFeature = new OGRFeature( poLayer->GetLayerDefn() );    // POINT_ID    poFeature->SetField( 0, atoi(papoGroup[0]->GetField( 3, 8 )) );    // Geometry    int         nGeomId;        poFeature->SetGeometryDirectly(poReader->ProcessGeometry(papoGroup[1],                                                             &nGeomId));    poFeature->SetField( 1, nGeomId );    // Attributes    poReader->ApplyAttributeValues( poFeature, papoGroup,                                    "FC", 2, "OD", 3, "JN", 4, "SN", 5,                                    NULL );    return poFeature;}/************************************************************************//*                         TranslateOscarLine()                         *//************************************************************************/static OGRFeature *TranslateOscarLine( NTFFileReader *poReader,                                       OGRNTFLayer *poLayer,                                       NTFRecord **papoGroup ){    if( CSLCount((char **) papoGroup) < 2        || papoGroup[0]->GetType() != NRT_LINEREC        || papoGroup[1]->GetType() != NRT_GEOMETRY )        return NULL;            OGRFeature  *poFeature = new OGRFeature( poLayer->GetLayerDefn() );    // LINE_ID    poFeature->SetField( 0, atoi(papoGroup[0]->GetField( 3, 8 )) );    // Geometry    int         nGeomId;        poFeature->SetGeometryDirectly(poReader->ProcessGeometry(papoGroup[1],                                                             &nGeomId));    poFeature->SetField( 1, nGeomId );    // Attributes    poReader->ApplyAttributeValues( poFeature, papoGroup,                                    "FC", 2, "OD", 3, "PN", 4, "LL", 5,                                    "SC", 6, "FW", 7, "RN", 8, "TR", 9,                                    NULL );    return poFeature;}/************************************************************************//*                      TranslateOscarRoutePoint()                      *//************************************************************************/static OGRFeature *TranslateOscarRoutePoint( NTFFileReader *poReader,                                             OGRNTFLayer *poLayer,                                             NTFRecord **papoGroup ){    if( CSLCount((char **) papoGroup) < 2        || papoGroup[0]->GetType() != NRT_POINTREC        || papoGroup[1]->GetType() != NRT_GEOMETRY )        return NULL;            OGRFeature  *poFeature = new OGRFeature( poLayer->GetLayerDefn() );    // POINT_ID    poFeature->SetField( 0, atoi(papoGroup[0]->GetField( 3, 8 )) );    // Geometry    int         nGeomId;        poFeature->SetGeometryDirectly(poReader->ProcessGeometry(papoGroup[1],                                                             &nGeomId));    poFeature->SetField( 1, nGeomId );    // Attributes    poReader->ApplyAttributeValues( poFeature, papoGroup,                                    "FC", 2, "OD", 3, "JN", 4, "SN", 5,                                    "NP", 6, "RT", 8,                                    NULL );    // PARENT_OSODR    char        **papszTypes, **papszValues;    if( poReader->ProcessAttRecGroup( papoGroup, &papszTypes, &papszValues ) )    {        char    **papszOSODRList = NULL;        for( int i = 0; papszTypes != NULL && papszTypes[i] != NULL; i++ )        {            if( EQUAL(papszTypes[i],"PO") )                papszOSODRList = CSLAddString(papszOSODRList,papszValues[i]);        }        poFeature->SetField( 7, papszOSODRList );        CPLAssert( CSLCount(papszOSODRList) ==                   poFeature->GetFieldAsInteger( 6 ) );        CSLDestroy( papszOSODRList );        CSLDestroy( papszTypes );        CSLDestroy( papszValues );    }    return poFeature;}/************************************************************************//*                      TranslateOscarRouteLine()                       *//************************************************************************/static OGRFeature *TranslateOscarRouteLine( NTFFileReader *poReader,                                            OGRNTFLayer *poLayer,                                            NTFRecord **papoGroup ){    if( CSLCount((char **) papoGroup) < 2        || papoGroup[0]->GetType() != NRT_LINEREC        || papoGroup[1]->GetType() != NRT_GEOMETRY )        return NULL;            OGRFeature  *poFeature = new OGRFeature( poLayer->GetLayerDefn() );    // LINE_ID    poFeature->SetField( 0, atoi(papoGroup[0]->GetField( 3, 8 )) );    // Geometry    int         nGeomId;        poFeature->SetGeometryDirectly(poReader->ProcessGeometry(papoGroup[1],                                                             &nGeomId));    poFeature->SetField( 1, nGeomId );    // Attributes    poReader->ApplyAttributeValues( poFeature, papoGroup,                                    "FC", 2, "OD", 3, "PN", 4, "LL", 5,                                    "RN", 6, "TR", 7, "NP", 8,                                     NULL );    // PARENT_OSODR    char        **papszTypes, **papszValues;    if( poReader->ProcessAttRecGroup( papoGroup, &papszTypes, &papszValues ) )    {        char    **papszOSODRList = NULL;        for( int i = 0; papszTypes != NULL && papszTypes[i] != NULL; i++ )        {            if( EQUAL(papszTypes[i],"PO") )                papszOSODRList = CSLAddString(papszOSODRList,papszValues[i]);        }        poFeature->SetField( 9, papszOSODRList );        CPLAssert( CSLCount(papszOSODRList) ==                   poFeature->GetFieldAsInteger( 8 ) );        CSLDestroy( papszOSODRList );        CSLDestroy( papszTypes );        CSLDestroy( papszValues );    }    return poFeature;}/************************************************************************//*                       TranslateOscarComment()                        *//************************************************************************/static OGRFeature *TranslateOscarComment( NTFFileReader *poReader,                                          OGRNTFLayer *poLayer,                                          NTFRecord **papoGroup ){    if( CSLCount((char **) papoGroup) != 1         || papoGroup[0]->GetType() != NRT_COMMENT )        return NULL;            OGRFeature  *poFeature = new OGRFeature( poLayer->GetLayerDefn() );    // RECORD_TYPE    poFeature->SetField( 0, atoi(papoGroup[0]->GetField( 3, 4 )) );    // RECORD_ID    poFeature->SetField( 1, papoGroup[0]->GetField( 5, 17 ) );    // CHANGE_TYPE    poFeature->SetField( 2, papoGroup[0]->GetField( 18, 18 ) );    return poFeature;}/************************************************************************//*                     TranslateOscarNetworkPoint()                     *//************************************************************************/static OGRFeature *TranslateOscarNetworkPoint( NTFFileReader *poReader,                                               OGRNTFLayer *poLayer,                                               NTFRecord **papoGroup ){    if( CSLCount((char **) papoGroup) < 2        || papoGroup[0]->GetType() != NRT_POINTREC        || papoGroup[1]->GetType() != NRT_GEOMETRY )        return NULL;            OGRFeature  *poFeature = new OGRFeature( poLayer->GetLayerDefn() );    // POINT_ID    poFeature->SetField( 0, atoi(papoGroup[0]->GetField( 3, 8 )) );    // Geometry    int         nGeomId;        poFeature->SetGeometryDirectly(poReader->ProcessGeometry(papoGroup[1],                                                             &nGeomId));    poFeature->SetField( 1, nGeomId );

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产不卡视频在线播放| 亚洲精品中文字幕乱码三区 | 国产精品美女视频| 91久久精品网| 91蜜桃网址入口| 成人激情免费电影网址| 国产美女娇喘av呻吟久久| 日本欧美一区二区三区| 一区二区视频在线| 中文字幕永久在线不卡| 欧美国产一区在线| 欧美激情在线一区二区三区| 久久噜噜亚洲综合| 91精品国产欧美日韩| 在线成人av网站| 欧美精品自拍偷拍| 777xxx欧美| 欧美熟乱第一页| 偷拍一区二区三区四区| 伊人一区二区三区| 中文字幕国产一区二区| 国产精品乱码人人做人人爱 | 成人久久18免费网站麻豆| 国产一级精品在线| 成人中文字幕合集| 欧美日韩色一区| 国产综合色在线| 国产乱国产乱300精品| 91丨九色丨黑人外教| 欧美日韩亚洲国产综合| 久久精品网站免费观看| 午夜精品123| 国产91精品久久久久久久网曝门| 欧美性色综合网| 欧美激情一区二区三区蜜桃视频 | 91久久精品国产91性色tv| 91精品国产综合久久婷婷香蕉| 欧美精品一区二区三区一线天视频 | 国产精品网曝门| 亚洲成人免费在线| 成人丝袜视频网| 欧美福利一区二区| 中文字幕亚洲一区二区av在线| 亚洲第一久久影院| 成人av资源下载| 26uuu欧美| 日本美女一区二区三区视频| 99久久精品免费观看| 久久综合久久综合亚洲| 日韩电影免费在线| 欧美体内she精高潮| 国产精品福利一区二区三区| 久久精品免费观看| 欧美精品高清视频| 亚洲高清在线视频| 91在线视频观看| 国产精品素人一区二区| 激情六月婷婷久久| 欧美videossexotv100| 无码av中文一区二区三区桃花岛| 91在线免费看| 1000精品久久久久久久久| 福利一区在线观看| 国产欧美一区二区三区网站| 国内不卡的二区三区中文字幕 | 国内久久精品视频| 91精品国产综合久久国产大片| 一区二区三区在线免费播放| av在线不卡免费看| 国产精品进线69影院| 成人精品视频一区二区三区| 久久久久成人黄色影片| 国产精品一品二品| 久久久影视传媒| 国产寡妇亲子伦一区二区| 久久精品日韩一区二区三区| 国产传媒日韩欧美成人| 国产亚洲精品精华液| 成人永久免费视频| 国产欧美视频一区二区三区| 成人午夜伦理影院| 亚洲色图一区二区| 欧美日韩中文字幕一区二区| 亚洲成人av电影| 91精品国产品国语在线不卡| 国内精品国产成人国产三级粉色| 26uuu精品一区二区| 成人一级视频在线观看| **网站欧美大片在线观看| 欧美亚洲一区二区在线| 日韩中文字幕区一区有砖一区 | 久久精品人人做人人综合| 成人深夜视频在线观看| 最新久久zyz资源站| 欧美午夜精品久久久久久孕妇 | 五月天视频一区| www成人在线观看| 本田岬高潮一区二区三区| 一区二区三区在线看| 欧美久久婷婷综合色| 国产精一区二区三区| 中文字幕中文字幕一区二区| 在线一区二区观看| 日韩va欧美va亚洲va久久| 精品国产91九色蝌蚪| av亚洲精华国产精华精| 婷婷亚洲久悠悠色悠在线播放| 日韩欧美亚洲一区二区| 成人av在线影院| 美女任你摸久久| 亚洲三级在线免费观看| 日韩欧美中文字幕一区| 91在线观看一区二区| 免费看欧美女人艹b| 成人欧美一区二区三区| 精品999在线播放| 欧洲色大大久久| 国产河南妇女毛片精品久久久 | 国精产品一区一区三区mba桃花 | 日韩欧美一级精品久久| 99国产精品久久久久| 久久97超碰国产精品超碰| 亚洲狼人国产精品| 国产欧美日韩综合| 欧美成人高清电影在线| 色成年激情久久综合| 成人午夜免费电影| 国产一区二区导航在线播放| 三级一区在线视频先锋| 亚洲精品乱码久久久久久| 国产亚洲人成网站| 日韩精品一区二区三区四区视频| 色婷婷综合久久久| av激情成人网| 国产成人av电影在线| 国产一区二区三区香蕉| 日本在线不卡视频| 日韩精品每日更新| 亚洲福利视频三区| 亚洲一区二区av在线| 亚洲精品免费在线| 亚洲三级在线看| 亚洲女与黑人做爰| 综合久久国产九一剧情麻豆| 中文字幕精品一区二区精品绿巨人 | 日欧美一区二区| 婷婷一区二区三区| 午夜a成v人精品| 天天av天天翘天天综合网色鬼国产| 亚洲欧美日韩系列| 最新日韩av在线| 亚洲美女电影在线| 亚洲自拍偷拍av| 亚洲成人福利片| 午夜一区二区三区视频| 午夜视黄欧洲亚洲| 人人超碰91尤物精品国产| 日韩主播视频在线| 久久精品噜噜噜成人88aⅴ| 九色|91porny| 国产成人午夜视频| 99精品欧美一区| 在线欧美日韩精品| 欧美日本一区二区在线观看| 9191国产精品| 2021久久国产精品不只是精品| 久久精品免视看| 中文字幕一区二区三区在线播放 | 成人午夜碰碰视频| 99久久99久久精品免费观看 | 国产成人亚洲精品狼色在线| 国产精品888| 91丨porny丨户外露出| 欧美肥妇free| 久久久精品免费观看| 亚洲欧美另类久久久精品 | 国产精品国产自产拍在线| 亚洲欧洲美洲综合色网| 三级影片在线观看欧美日韩一区二区 | 亚欧色一区w666天堂| 蜜乳av一区二区三区| 国产不卡在线一区| 欧美日韩第一区日日骚| 2023国产精品自拍| 亚洲自拍偷拍图区| 国产精品白丝jk白祙喷水网站| 91美女视频网站| 精品免费一区二区三区| 国产精品国产三级国产普通话99| 亚洲国产一区二区在线播放| 国产资源在线一区| 欧美午夜免费电影| 国产亚洲欧美日韩日本| 亚洲国产另类av| www.色综合.com| 日韩三级高清在线| 亚洲国产综合视频在线观看| 国产91精品免费| 日韩精品中文字幕在线一区| 一区二区三区精品视频在线|