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

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

?? mitab_feature_mif.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
/********************************************************************** * $Id: mitab_feature_mif.cpp,v 1.31 2006/01/27 13:44:44 fwarmerdam Exp $ * * Name:     mitab_feature.cpp * Project:  MapInfo TAB Read/Write library * Language: C++ * Purpose:  Implementation of R/W Fcts for (Mid/Mif) in feature classes  *           specific to MapInfo files. * Author:   Stephane Villeneuve, stephane.v@videotron.ca * ********************************************************************** * Copyright (c) 1999-2002, Stephane Villeneuve * * 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. ********************************************************************** * * $Log: mitab_feature_mif.cpp,v $ * Revision 1.31  2006/01/27 13:44:44  fwarmerdam * fixed Mills.mif reading, crash at file end * * Revision 1.30  2006/01/26 21:26:36  fwarmerdam * fixed bug with multi character delimeters in .mid file * * Revision 1.29  2005/10/04 19:36:10  dmorissette * Added support for reading collections from MIF files (bug 1126) * * Revision 1.28  2005/10/04 15:44:31  dmorissette * First round of support for Collection objects. Currently supports reading * from .TAB/.MAP and writing to .MIF. Still lacks symbol support and write * support. (Based in part on patch and docs from Jim Hope, bug 1126) * * Revision 1.27  2005/10/04 15:35:52  dmorissette * Fixed an instance of hardcoded delimiter (",") in WriteRecordToMIDFile() * (patch by KB Kieron, bug 1126) * * Revision 1.26  2005/07/14 16:15:05  jlacroix * \n and \ are now unescaped internally. * * Revision 1.25  2003/12/19 07:52:34  fwarmerdam * write 3d as 2d * * Revision 1.24  2002/11/27 22:51:52  daniel * Bug 1631:Do not produce an error if .mid data records end with a stray ',' * Treat tabs (\t) as a blank space delimiter when reading .mif coordinates * * Revision 1.23  2002/10/29 21:09:20  warmerda * Ensure that a blank line in a mid file is treated as one field containing * an empty string. * * Revision 1.22  2002/04/26 14:16:49  julien * Finishing the implementation of Multipoint (support for MIF) * * Revision 1.21  2002/03/26 01:48:40  daniel * Added Multipoint object type (V650) * * Revision 1.20  2002/01/23 20:31:21  daniel * Fixed warning produced by CPLAssert() in non-DEBUG mode. * * Revision 1.19  2001/06/25 01:50:42  daniel * Fixed MIF Text object output: negative text angles were lost.  Also use * TABText::SetTextAngle() when reading MIF instead of setting class members * directly so that negative angles get converted to the [0..360] range. * * Revision 1.18  2001/02/28 07:15:09  daniel * Added support for text label line end point * * Revision 1.17  2001/01/22 16:03:58  warmerda * expanded tabs * * Revision 1.16  2000/10/03 19:29:51  daniel * Include OGR StyleString stuff (implemented by Stephane) * * Revision 1.15  2000/09/28 16:39:44  warmerda * avoid warnings for unused, and unitialized variables * * Revision 1.14  2000/09/19 17:23:53  daniel * Maintain and/or compute valid region and polyline center/label point * * Revision 1.13  2000/03/27 03:33:45  daniel * Treat SYMBOL line as optional when reading TABPoint * * Revision 1.12  2000/02/28 16:56:32  daniel * Support pen width in points (width values 11 to 2047) * * Revision 1.11  2000/01/15 22:30:44  daniel * Switch to MIT/X-Consortium OpenSource license * * Revision 1.10  2000/01/14 23:51:37  daniel * Fixed handling of "\n" in TABText strings... now the external interface * of the lib returns and expects escaped "\"+"n" as described in MIF specs * * Revision 1.9  1999/12/19 17:37:14  daniel * Fixed memory leaks * * Revision 1.8  1999/12/19 01:02:50  stephane * Add a test on the CENTER information * * Revision 1.7  1999/12/18 23:23:23  stephane * Change the format of the output double from %g to %.16g * * Revision 1.6  1999/12/18 08:22:57  daniel * Removed stray break statement in PLINE MULTIPLE write code * * Revision 1.5  1999/12/18 07:21:30  daniel * Fixed test on geometry type when writing OGRMultiLineStrings * * Revision 1.4  1999/12/18 07:11:57  daniel * Return regions as OGRMultiPolygons instead of multiple rings OGRPolygons * * Revision 1.3  1999/12/16 17:16:44  daniel * Use addRing/GeometryDirectly() (prevents leak), and rounded rectangles * always return real corner radius from file even if it is bigger than MBR * * Revision 1.2  1999/11/11 01:22:05  stephane * Remove DebugFeature call, Point Reading error, add IsValidFeature() to  * test correctly if we are on a feature * * Revision 1.1  1999/11/08 19:20:30  stephane * First version * * Revision 1.1  1999/11/08 04:16:07  stephane * First Revision * * **********************************************************************/#include "mitab.h"#include "mitab_utils.h"#include <ctype.h>/*===================================================================== *                      class TABFeature *====================================================================*//************************************************************************//*                            MIDTokenize()                             *//*                                                                      *//*      We implement a special tokenize function so we can handle       *//*      multibyte delimeters (ie. MITAB bug 1266).                      *//*                                                                      *//*      http://bugzilla.maptools.org/show_bug.cgi?id=1266               *//************************************************************************/static char **MIDTokenize( const char *pszLine, const char *pszDelim ){    char **papszResult = NULL;    int iChar, iTokenChar = 0, bInQuotes = FALSE;    char *pszToken = (char *) CPLMalloc(strlen(pszLine)+1);    int nDelimLen = strlen(pszDelim);    for( iChar = 0; pszLine[iChar] != '\0'; iChar++ )    {        if( bInQuotes && pszLine[iChar] == '\\' && pszLine[iChar+1] == '"' )        {            pszToken[iTokenChar++] = '"';            iChar++;        }        else if( pszLine[iChar] == '"' )        {            bInQuotes = !bInQuotes;        }        else if( !bInQuotes && strncmp(pszLine+iChar,pszDelim,nDelimLen) == 0 )        {            pszToken[iTokenChar++] = '\0';            papszResult = CSLAddString( papszResult, pszToken );                        iChar += strlen(pszDelim) - 1;            iTokenChar = 0;        }        else        {            pszToken[iTokenChar++] = pszLine[iChar];        }    }    pszToken[iTokenChar++] = '\0';    papszResult = CSLAddString( papszResult, pszToken );    CPLFree( pszToken );    return papszResult;}/********************************************************************** *                   TABFeature::ReadRecordFromMIDFile() * *  This method is used to read the Record (Attributs) for all type of *  feature included in a mid/mif file. *  * Returns 0 on success, -1 on error, in which case CPLError() will have * been called. **********************************************************************/int TABFeature::ReadRecordFromMIDFile(MIDDATAFile *fp){    const char       *pszLine;    char            **papszToken;    int               nFields,i;    nFields = GetFieldCount();        pszLine = fp->GetLastLine();    if (pszLine == NULL)    {        CPLError(CE_Failure, CPLE_FileIO,               "Unexpected EOF while reading attribute record from MID file.");        return -1;    }    papszToken = MIDTokenize( pszLine, fp->GetDelimiter() );    // Ensure that a blank line in a mid file is treated as one field     // containing an empty string.    if( nFields == 1 && CSLCount(papszToken) == 0 && pszLine[0] == '\0' )        papszToken = CSLAddString(papszToken,"");    // Make sure we found at least the expected number of field values.    // Note that it is possible to have a stray delimiter at the end of    // the line (mif/mid files from Geomedia), so don't produce an error    // if we find more tokens than expected.    if (CSLCount(papszToken) < nFields)    {        CSLDestroy(papszToken);        return -1;    }    for (i=0;i<nFields;i++)    {        SetField(i,papszToken[i]);    }        fp->GetLine();    CSLDestroy(papszToken);    return 0;}/********************************************************************** *                   TABFeature::WriteRecordToMIDFile() * *  This methode is used to write the Record (Attributs) for all type *  of feature included in a mid file. * *  Return 0 on success, -1 on error **********************************************************************/int TABFeature::WriteRecordToMIDFile(MIDDATAFile *fp){    int                  iField, numFields;    OGRFieldDefn        *poFDefn = NULL;    CPLAssert(fp);        const char *delimiter = fp->GetDelimiter();    numFields = GetFieldCount();    for(iField=0; iField<numFields; iField++)    {        if (iField != 0)          fp->WriteLine(delimiter);        poFDefn = GetFieldDefnRef( iField );        switch(poFDefn->GetType())        {          case OFTString:            fp->WriteLine("\"%s\"",GetFieldAsString(iField));            break;                    default:            fp->WriteLine("%s",GetFieldAsString(iField));        }    }    fp->WriteLine("\n");    return 0;}/********************************************************************** *                   TABFeature::ReadGeometryFromMIFFile() * * In derived classes, this method should be reimplemented to * fill the geometry and representation (color, etc...) part of the * feature from the contents of the .MAP object pointed to by poMAPFile. * * It is assumed that before calling ReadGeometryFromMAPFile(), poMAPFile * currently points to the beginning of a map object. * * The current implementation does nothing since instances of TABFeature * objects contain no geometry (i.e. TAB_GEOM_NONE). *  * Returns 0 on success, -1 on error, in which case CPLError() will have * been called. **********************************************************************/int TABFeature::ReadGeometryFromMIFFile(MIDDATAFile *fp){    const char *pszLine;        /* Go to the first line of the next feature */    while (((pszLine = fp->GetLine()) != NULL) &&            fp->IsValidFeature(pszLine) == FALSE)      ;    return 0;}/********************************************************************** *                   TABFeature::WriteGeometryToMIFFile() * * * In derived classes, this method should be reimplemented to * write the geometry and representation (color, etc...) part of the * feature to the .MAP object pointed to by poMAPFile. * * It is assumed that before calling WriteGeometryToMAPFile(), poMAPFile * currently points to a valid map object. * * The current implementation does nothing since instances of TABFeature * objects contain no geometry. *  * Returns 0 on success, -1 on error, in which case CPLError() will have * been called. **********************************************************************/int TABFeature::WriteGeometryToMIFFile(MIDDATAFile *fp){    fp->WriteLine("NONE\n");    return 0;}/********************************************************************** * **********************************************************************/int TABPoint::ReadGeometryFromMIFFile(MIDDATAFile *fp){      OGRGeometry         *poGeometry;        char               **papszToken;    const char *pszLine;    double dfX,dfY;    papszToken = CSLTokenizeString2(fp->GetSavedLine(),                                     " \t", CSLT_HONOURSTRINGS);         if (CSLCount(papszToken) !=3)    {        CSLDestroy(papszToken);        return -1;    }        dfX = fp->GetXTrans(atof(papszToken[1]));    dfY = fp->GetYTrans(atof(papszToken[2]));    CSLDestroy(papszToken);    papszToken = NULL;    // Read optional SYMBOL line...    pszLine = fp->GetLastLine();    if( pszLine != NULL )        papszToken = CSLTokenizeStringComplex(pszLine," ,()\t",                                              TRUE,FALSE);    if (CSLCount(papszToken) == 4 && EQUAL(papszToken[0], "SYMBOL") )    {        SetSymbolNo(atoi(papszToken[1]));        SetSymbolColor(atoi(papszToken[2]));        SetSymbolSize(atoi(papszToken[3]));    }    CSLDestroy(papszToken);     papszToken = NULL;    // scan until we reach 1st line of next feature    // Since SYMBOL is optional, we have to test IsValidFeature() on that    // line as well.    while (pszLine && fp->IsValidFeature(pszLine) == FALSE)    {        pszLine = fp->GetLine();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产91精品入口| 国产精品亲子乱子伦xxxx裸| 日韩精品一区二| 欧美精品一区二区三区蜜臀 | 亚洲精品视频免费观看| 奇米影视在线99精品| 另类欧美日韩国产在线| 欧美va亚洲va| 日日噜噜夜夜狠狠视频欧美人| 日本成人在线不卡视频| 精品一区二区精品| 成人91在线观看| 狠狠色综合播放一区二区| 国产成人亚洲精品狼色在线 | 国产女人水真多18毛片18精品视频 | 一区二区三区高清不卡| 日本在线不卡一区| 国产东北露脸精品视频| 欧美午夜在线观看| 久久新电视剧免费观看| 亚洲综合色区另类av| 久久国产精品99久久久久久老狼| 国产精品18久久久久久久久久久久| 国产宾馆实践打屁股91| 欧美色男人天堂| 日韩视频免费观看高清完整版在线观看| 国产亚洲va综合人人澡精品| 亚洲午夜精品网| 国产精品一区二区视频| 欧美日韩视频专区在线播放| 国产女人18毛片水真多成人如厕| 亚洲一区在线播放| 国产成人高清在线| 日韩一区国产二区欧美三区| 亚洲免费观看高清| 国产成人亚洲综合a∨婷婷| 91精品国产色综合久久不卡电影| 亚洲欧美一区二区不卡| 国产真实精品久久二三区| 日本高清不卡在线观看| 久久婷婷综合激情| 亚洲综合一二三区| 国产成人一区在线| 日韩免费看的电影| 亚洲一区二区三区四区在线观看 | 欧美xxxx老人做受| 亚洲国产精品天堂| 99国产精品久久久久久久久久久| 精品久久久久久久久久久久久久久 | 六月婷婷色综合| 精品视频一区 二区 三区| 国产精品乱人伦一区二区| 久草在线在线精品观看| 欧美三级在线看| 亚洲乱码一区二区三区在线观看| 国产91丝袜在线18| 精品奇米国产一区二区三区| 日韩av电影免费观看高清完整版| 在线免费观看成人短视频| 中文字幕一区二区三中文字幕| 国产久卡久卡久卡久卡视频精品| 日韩欧美国产一二三区| 日本免费新一区视频| 欧美日韩国产三级| 亚洲一区二区三区中文字幕 | 日韩av电影免费观看高清完整版| 欧美日韩一区久久| 亚洲国产一区二区三区| 色国产精品一区在线观看| 亚洲视频电影在线| 99久久婷婷国产综合精品电影| 国产日韩欧美不卡在线| 国产成人精品亚洲日本在线桃色| 久久久久久免费网| 国产激情一区二区三区四区 | av在线不卡免费看| 国产精品家庭影院| 99久久国产综合色|国产精品| 国产精品美日韩| 97国产一区二区| 亚洲天堂网中文字| 91久久精品一区二区二区| 一区二区欧美视频| 欧美在线free| 午夜电影一区二区三区| 69久久夜色精品国产69蝌蚪网| 日本美女一区二区三区视频| 日韩女同互慰一区二区| 国产精品资源网| 欧美国产激情二区三区| 99久久精品情趣| 一区二区三区产品免费精品久久75| 91久久国产综合久久| 亚洲成人av电影| 日韩欧美亚洲国产精品字幕久久久| 精品亚洲国产成人av制服丝袜| 国产欧美日韩另类视频免费观看| 不卡欧美aaaaa| 亚洲黄色小视频| 91精品国产入口| 国产精品99久久不卡二区| 中文字幕一区二区不卡| 91国偷自产一区二区三区成为亚洲经典 | 国产成+人+日韩+欧美+亚洲 | 欧美三级视频在线观看| 美女网站色91| 日本一区二区三区四区在线视频| 91在线视频免费观看| 亚洲成人1区2区| 久久综合网色—综合色88| 成人av资源下载| 亚洲成人激情综合网| 精品粉嫩超白一线天av| www.亚洲色图.com| 午夜精品久久久| 国产亚洲美州欧州综合国| 91麻豆国产在线观看| 首页亚洲欧美制服丝腿| 久久久不卡影院| 色综合中文综合网| 国产精品不卡一区| 9191久久久久久久久久久| 毛片av一区二区| 国产精品久线观看视频| 91麻豆精品国产综合久久久久久| 国产v综合v亚洲欧| 亚洲一区二区视频在线观看| 国产亚洲女人久久久久毛片| 欧美日韩大陆一区二区| 大白屁股一区二区视频| 精品亚洲porn| 亚洲婷婷在线视频| 欧美一区三区四区| av一二三不卡影片| 久久超碰97人人做人人爱| 亚洲伦理在线精品| 国产日韩三级在线| 欧美一级高清片| 色视频成人在线观看免| 国产一区二区在线观看免费 | 欧美一区二区在线不卡| av电影天堂一区二区在线| 蜜桃视频第一区免费观看| 亚洲免费伊人电影| 欧美精品一区二区三区视频| 欧美日韩国产首页| 日本韩国精品一区二区在线观看| 成人一二三区视频| 免费一区二区视频| 亚洲一区中文在线| 国产丝袜在线精品| 欧美大片一区二区| 欧美日韩三级一区二区| av资源网一区| 国产精品一区二区免费不卡| 日本人妖一区二区| 亚洲电影一级片| 亚洲精品国产品国语在线app| 国产午夜精品在线观看| 日韩精品最新网址| 欧美一级午夜免费电影| 欧美日韩国产综合一区二区| 色呦呦日韩精品| 波多野结衣欧美| 精东粉嫩av免费一区二区三区 | 666欧美在线视频| 在线观看亚洲精品视频| 97国产精品videossex| www.久久久久久久久| 懂色av一区二区三区免费观看| 久久黄色级2电影| 日韩精品一二区| 丝袜亚洲另类欧美综合| 亚洲愉拍自拍另类高清精品| 亚洲激情五月婷婷| 亚洲日本在线天堂| 亚洲人成影院在线观看| 亚洲色图视频网| 亚洲男人天堂av| 亚洲人成亚洲人成在线观看图片| 亚洲人成网站影音先锋播放| 国产精品久久久久久久第一福利| 亚洲国产精品成人综合色在线婷婷| 国产亚洲一本大道中文在线| 欧美精品一区二区三区很污很色的| 日韩一级视频免费观看在线| 日韩欧美的一区| 欧美一区二区性放荡片| 日韩精品中文字幕在线不卡尤物| 欧美美女激情18p| 欧美一区二区三区不卡| 日韩精品在线看片z| 欧美精三区欧美精三区| 91精选在线观看| 欧美日韩日日骚| 欧美精品1区2区3区| 欧美一区二区三区在| 欧美成人午夜电影| 久久久精品黄色| 中文字幕精品综合|