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

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

?? mitab_tabfile.cpp

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
/********************************************************************** * $Id: mitab_tabfile.cpp,v 1.59 2006/02/08 05:02:58 dmorissette Exp $ * * Name:     mitab_tabfile.cpp * Project:  MapInfo TAB Read/Write library * Language: C++ * Purpose:  Implementation of the TABFile class, the main class of the lib. *           To be used by external programs to handle reading/writing of *           features from/to TAB datasets. * Author:   Daniel Morissette, dmorissette@dmsolutions.ca * ********************************************************************** * Copyright (c) 1999-2003, Daniel Morissette * * 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_tabfile.cpp,v $ * Revision 1.59  2006/02/08 05:02:58  dmorissette * Fixed crash when attempting to write TABPolyline object with an invalid * geometry (GDAL bug 1059) * * Revision 1.58  2005/10/13 20:12:03  fwarmerdam * layers with just regions can't be set as type wkbPolygon because they may * have multipolygons (bug GDAL:958) *     http://bugzilla.remotesensing.org/show_bug.cgi?id=958 * * Revision 1.57  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.56  2004/09/17 19:26:23  fwarmerdam * Several fixes in error/failure cases in TABFile::Open() care of * Stephen Cheesman of GeoSoft. * * Revision 1.55  2004/06/30 20:29:04  dmorissette * Fixed refs to old address danmo@videotron.ca * * Revision 1.54  2004/05/20 13:49:46  fwarmerdam * Removed special bailout for m_poMAPFile == NULL in TABFile::Close(). * It is important to cleanup other used memory. * * Revision 1.53  2003/01/18 20:22:39  daniel * Fixed leak of TABMAPObjHdr when writing NONE geometries in SetFeature() * * Revision 1.52  2002/09/23 13:15:35  warmerda * fixed memory leak in SetMIFCoordSys * * Revision 1.51  2002/09/23 13:06:21  warmerda * ensure pre-created m_poDefn is referenced properly * * Revision 1.50  2002/08/27 17:19:22  warmerda * auto-add FID column if there aren't any columns * * Revision 1.49  2002/03/26 01:48:40  daniel * Added Multipoint object type (V650) * * Revision 1.48  2001/11/19 15:08:50  daniel * Handle the case of TAB_GEOM_NONE with the new TABMAPObjHdr classes. * * Revision 1.47  2001/11/17 21:54:06  daniel * Made several changes in order to support writing objects in 16 bits  * coordinate format. New TABMAPObjHdr-derived classes are used to hold  * object info in mem until block is full. * * Revision 1.46  2001/09/19 21:39:31  warmerda * improved capabilities logic * * Revision 1.45  2001/09/14 19:14:43  warmerda * added attribute query support * * Revision 1.44  2001/09/14 03:23:55  warmerda * Substantial upgrade to support spatial queries using spatial indexes * * Revision 1.43  2001/03/15 03:57:51  daniel * Added implementation for new OGRLayer::GetExtent(), returning data MBR. * * Revision 1.42  2001/03/09 04:14:19  daniel * Fixed problem creating new files with mixed case extensions (e.g. ".Tab") * * Revision 1.41  2001/01/23 21:23:42  daniel * Added projection bounds lookup table, called from TABFile::SetProjInfo() * * Revision 1.40  2001/01/22 16:03:58  warmerda * expanded tabs * * Revision 1.39  2000/12/15 05:32:31  daniel * Handle table type LINKED the same way as table type NATIVE. * Make sure max char field width is 254 in AddFieldNative(). * * Revision 1.38  2000/10/18 03:53:16  daniel * GetBounds() now calculates bounds based on +/- 1e9 integer coordinates limit * * Revision 1.37  2000/09/20 18:32:02  daniel * Accept "FORMAT: DBF" in version 100 .tab headers * * Revision 1.36  2000/09/07 23:32:13  daniel * Added RecordDeletedFlag to TABFeature with get/set methods * * Revision 1.35  2000/07/04 01:50:02  warmerda * removed unprotected debugging printf. * * Revision 1.34  2000/06/28 00:31:05  warmerda * Try to set geometry type on OGRFeatureDefn by feature count * * Revision 1.33  2000/03/19 23:22:43  daniel * Fixed test on return value of SetSpatialRef() in SetMIFCoordSys() * * Revision 1.32  2000/02/28 17:11:14  daniel * Support indexed fields and new V450 object types * * Revision 1.31  2000/02/18 20:45:56  daniel * Validate field names on write * * Revision 1.30  2000/01/26 18:18:01  warmerda * fixed capabilities test * * Revision 1.29  2000/01/18 23:13:05  daniel * Added missing m_poDefn->Reference() * * Revision 1.28  2000/01/18 22:14:36  daniel * Fixed compile warnings * * Revision 1.27  2000/01/16 19:08:49  daniel * Added support for reading 'Table Type DBF' tables * * ... * * Revision 1.1  1999/07/12 04:18:25  daniel * Initial checkin * **********************************************************************/#include "mitab.h"#include "mitab_utils.h"#include <ctype.h>      /* isspace() *//*===================================================================== *                      class TABFile *====================================================================*//********************************************************************** *                   TABFile::TABFile() * * Constructor. **********************************************************************/TABFile::TABFile(){    m_eAccessMode = TABRead;    m_pszFname = NULL;    m_papszTABFile = NULL;    m_nVersion = 300;    m_pszCharset = NULL;    m_eTableType = TABTableNative;    m_poMAPFile = NULL;    m_poDATFile = NULL;    m_poINDFile = NULL;    m_poDefn = NULL;    m_poSpatialRef = NULL;    m_poCurFeature = NULL;    m_nCurFeatureId = 0;    m_nLastFeatureId = 0;    m_panIndexNo = NULL;    bUseSpatialTraversal = FALSE;}/********************************************************************** *                   TABFile::~TABFile() * * Destructor. **********************************************************************/TABFile::~TABFile(){    Close();}/************************************************************************//*                          GetFeatureCount()                           *//************************************************************************/int TABFile::GetFeatureCount (int bForce){        if( m_poFilterGeom != NULL || m_poAttrQuery != NULL )        return OGRLayer::GetFeatureCount( bForce );    else        return m_nLastFeatureId;}/************************************************************************//*                            ResetReading()                            *//************************************************************************/void TABFile::ResetReading(){    m_nCurFeatureId = 0;    if( m_poMAPFile != NULL )        m_poMAPFile->ResetReading();/* -------------------------------------------------------------------- *//*      Decide whether to operate in spatial traversal mode or not,     *//*      and ensure the current spatial filter is applied to the map     *//*      file object.                                                    *//* -------------------------------------------------------------------- */    if( m_poMAPFile )    {        bUseSpatialTraversal = FALSE;            m_poMAPFile->ResetCoordFilter();        if( m_poFilterGeom != NULL )        {            OGREnvelope  sEnvelope;            TABVertex sMin, sMax;            TABMAPHeaderBlock *poHeader;                poHeader = m_poMAPFile->GetHeaderBlock();            m_poFilterGeom->getEnvelope( &sEnvelope );            m_poMAPFile->GetCoordFilter( sMin, sMax );            if( sEnvelope.MinX > sMin.x                 || sEnvelope.MinY > sMin.y                || sEnvelope.MaxX < sMax.x                || sEnvelope.MaxY < sMax.y )            {                bUseSpatialTraversal = TRUE;                sMin.x = sEnvelope.MinX;                sMin.y = sEnvelope.MinY;                sMax.x = sEnvelope.MaxX;                sMax.y = sEnvelope.MaxY;                m_poMAPFile->SetCoordFilter( sMin, sMax );            }        }    }}/********************************************************************** *                   TABFile::Open() * * Open a .TAB dataset and the associated files, and initialize the  * structures to be ready to read features from (or write to) it. * * Supported access modes are "r" (read-only) and "w" (create new dataset). * * Set bTestOpenNoError=TRUE to silently return -1 with no error message * if the file cannot be opened.  This is intended to be used in the * context of a TestOpen() function.  The default value is FALSE which * means that an error is reported if the file cannot be opened. * * Note that dataset extents will have to be set using SetBounds() before * any feature can be written to a newly created dataset. * * In read mode, a valid dataset must have at least a .TAB and a .DAT file. * The .MAP and .ID files are optional and if they do not exist then * all features will be returned with NONE geometry. * * Returns 0 on success, -1 on error. **********************************************************************/int TABFile::Open(const char *pszFname, const char *pszAccess,                  GBool bTestOpenNoError /*=FALSE*/ ){    char *pszTmpFname = NULL;    int nFnameLen = 0;    CPLErrorReset();       if (m_poMAPFile)    {        CPLError(CE_Failure, CPLE_AssertionFailed,                 "Open() failed: object already contains an open file");        return -1;    }    /*-----------------------------------------------------------------     * Validate access mode     *----------------------------------------------------------------*/    if (EQUALN(pszAccess, "r", 1))    {        m_eAccessMode = TABRead;        pszAccess = "rb";    }    else if (EQUALN(pszAccess, "w", 1))    {        m_eAccessMode = TABWrite;        pszAccess = "wb";    }    else    {        if (!bTestOpenNoError)            CPLError(CE_Failure, CPLE_FileIO,                 "Open() failed: access mode \"%s\" not supported", pszAccess);        else            CPLErrorReset();        return -1;    }    /*-----------------------------------------------------------------     * Make sure filename has a .TAB extension...      *----------------------------------------------------------------*/    m_pszFname = CPLStrdup(pszFname);    nFnameLen = strlen(m_pszFname);    if (nFnameLen > 4 && (strcmp(m_pszFname+nFnameLen-4, ".TAB")==0 ||                     strcmp(m_pszFname+nFnameLen-4, ".MAP")==0 ||                     strcmp(m_pszFname+nFnameLen-4, ".DAT")==0 ) )        strcpy(m_pszFname+nFnameLen-4, ".TAB");    else if (nFnameLen > 4 && (EQUAL(m_pszFname+nFnameLen-4, ".tab") ||                               EQUAL(m_pszFname+nFnameLen-4, ".map") ||                               EQUAL(m_pszFname+nFnameLen-4, ".dat") ) )        strcpy(m_pszFname+nFnameLen-4, ".tab");    else    {        if (!bTestOpenNoError)            CPLError(CE_Failure, CPLE_FileIO,                     "Open() failed for %s: invalid filename extension",                     m_pszFname);        else            CPLErrorReset();        CPLFree(m_pszFname);        return -1;    }    pszTmpFname = CPLStrdup(m_pszFname);#ifndef _WIN32

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人h动漫精品| 久久久99精品久久| 欧美日韩一区二区三区高清| 成人黄色网址在线观看| 国产成人a级片| 国内久久精品视频| 国产一区视频在线看| 精品一区二区三区在线播放视频| 日韩精品一二区| 日本在线不卡视频一二三区| 婷婷成人激情在线网| 日韩高清国产一区在线| 六月婷婷色综合| 国产久卡久卡久卡久卡视频精品| 国产乱子轮精品视频| 国产成人午夜片在线观看高清观看| 91精品国产福利| 日韩精品最新网址| 久久影音资源网| 欧美国产精品v| 亚洲欧美经典视频| 亚洲影院理伦片| 日本欧美在线观看| 日韩国产精品大片| 国产综合色精品一区二区三区| 国产乱码精品一区二区三区五月婷| 国产一区二区三区在线观看精品| 国产999精品久久久久久绿帽| av在线播放成人| 91国内精品野花午夜精品| 欧美欧美欧美欧美| 精品国产乱码91久久久久久网站| 亚洲1区2区3区视频| 日本特黄久久久高潮 | 国产不卡一区视频| 91小视频在线观看| 91精品国产aⅴ一区二区| 久久久久99精品一区| 综合久久给合久久狠狠狠97色| 亚洲一卡二卡三卡四卡无卡久久 | 亚洲精品国产高清久久伦理二区| 亚洲电影视频在线| 精品无码三级在线观看视频 | 久久嫩草精品久久久久| 亚洲人午夜精品天堂一二香蕉| 无码av中文一区二区三区桃花岛| 麻豆91免费看| 91社区在线播放| 7777精品伊人久久久大香线蕉| 久久色成人在线| 亚洲摸摸操操av| 国产一区二区成人久久免费影院| 一本久久精品一区二区| 精品蜜桃在线看| 一区二区三区高清| 国产美女一区二区三区| 欧美中文字幕不卡| 国产亚洲精品aa| 日韩电影在线一区二区| gogogo免费视频观看亚洲一| 日韩一区二区精品在线观看| 国产精品久久免费看| 美女国产一区二区三区| 91美女在线观看| 久久久久久久久久久久电影| 亚洲国产乱码最新视频| 成人午夜av电影| 日韩欧美国产一区二区三区| 一区二区三区精品久久久| 国产露脸91国语对白| 欧美老肥妇做.爰bbww| 综合激情成人伊人| 国产精品一区二区三区网站| 欧美人与z0zoxxxx视频| 亚洲老司机在线| 国产成人免费视频网站| 日韩一区二区免费在线观看| 亚洲电影视频在线| 一本久道久久综合中文字幕| 久久久久国产成人精品亚洲午夜| 日韩不卡一二三区| 在线观看国产一区二区| 国产精品国产馆在线真实露脸 | 99r精品视频| wwww国产精品欧美| 日韩专区一卡二卡| 欧美亚洲图片小说| 亚洲你懂的在线视频| 不卡视频一二三| 国产亚洲1区2区3区| 国产九色sp调教91| 久久免费的精品国产v∧| 久久成人羞羞网站| 日韩一级二级三级精品视频| 午夜精品福利一区二区三区蜜桃| 91国产丝袜在线播放| 亚洲综合色自拍一区| 色国产精品一区在线观看| 中文字幕视频一区二区三区久| 紧缚奴在线一区二区三区| 欧美一级爆毛片| 精品在线观看视频| 精品久久久三级丝袜| 黑人精品欧美一区二区蜜桃| 日韩精品一区国产麻豆| 免费观看在线综合色| 欧美成人video| 精品一区二区三区免费| 久久综合网色—综合色88| 国产在线精品视频| 国产偷v国产偷v亚洲高清| 国产福利精品导航| 国产精品视频免费看| 99久久久免费精品国产一区二区| 国产精品不卡视频| 色综合欧美在线| 亚洲国产成人av网| 日韩一级高清毛片| 国产福利精品导航| 综合亚洲深深色噜噜狠狠网站| 色哟哟亚洲精品| 亚洲国产精品嫩草影院| 91精品国产黑色紧身裤美女| 久久国产尿小便嘘嘘尿| 欧美激情一区在线| av一区二区不卡| 亚洲超碰97人人做人人爱| 日韩欧美资源站| 国产精品 欧美精品| 国产精品国模大尺度视频| 91视频.com| 全部av―极品视觉盛宴亚洲| 26uuu精品一区二区| 成人激情小说网站| 亚洲一区二区三区影院| 日韩精品一区二区三区在线播放| 成人综合婷婷国产精品久久蜜臀| 亚洲精品中文在线观看| 在线播放一区二区三区| 国产精品一区二区免费不卡| 自拍偷自拍亚洲精品播放| 欧美精品久久久久久久久老牛影院| 久久99国内精品| 亚洲色图在线看| 日韩欧美激情一区| 91女人视频在线观看| 免费人成精品欧美精品| 国产精品免费久久| 欧美电影在线免费观看| 成人在线视频首页| 日韩精品一级二级| 国产精品久久久久久久午夜片| 欧美性猛交xxxx乱大交退制版| 激情六月婷婷综合| 亚洲精品一二三| 久久精品一区四区| 欧美日韩国产三级| 成人免费视频一区二区| 日韩av中文字幕一区二区三区| 国产精品毛片高清在线完整版| 欧美日韩精品高清| 成人激情综合网站| 精品一区二区三区香蕉蜜桃| 一区二区三区成人| 国产日韩欧美精品在线| 欧美日韩精品一区二区天天拍小说| 成人一区二区在线观看| 蜜臀av亚洲一区中文字幕| 18欧美亚洲精品| 精品国产乱子伦一区| 欧美理论电影在线| 在线视频你懂得一区| 丁香婷婷综合激情五月色| 日韩av电影免费观看高清完整版在线观看| 国产精品欧美一区二区三区| 欧美成人在线直播| 精品视频在线看| 97精品国产97久久久久久久久久久久| 久久精品国产亚洲高清剧情介绍 | 久久久精品综合| 91精品国产福利在线观看| 色综合中文字幕国产| 精品制服美女久久| 日日夜夜免费精品视频| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲精品第一国产综合野| 欧美国产日韩一二三区| 日韩欧美国产电影| 777奇米成人网| 欧美日韩国产高清一区二区| 91美女精品福利| 99在线精品免费| heyzo一本久久综合| 成人涩涩免费视频| 国产成人99久久亚洲综合精品| 国产一区二区精品久久99| 精品一区二区三区香蕉蜜桃 | 国产福利精品一区| 国产精品亚洲一区二区三区妖精| 人人精品人人爱|