mirror of
https://github.com/ultimatepp/ultimatepp.git
synced 2026-06-19 14:15:21 -06:00
211 lines
8.1 KiB
C++
211 lines
8.1 KiB
C++
/******************************************************************************
|
|
* $Id: sdtspointreader.cpp 10645 2007-01-18 02:22:39Z warmerdam $
|
|
*
|
|
* Project: SDTS Translator
|
|
* Purpose: Implementation of SDTSPointReader and SDTSRawPoint classes.
|
|
* 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 "sdts_al.h"
|
|
|
|
CPL_CVSID("$Id: sdtspointreader.cpp 10645 2007-01-18 02:22:39Z warmerdam $");
|
|
|
|
/************************************************************************/
|
|
/* ==================================================================== */
|
|
/* SDTSRawPoint */
|
|
/* */
|
|
/* This is a simple class for holding the data related with a */
|
|
/* point feature. */
|
|
/* ==================================================================== */
|
|
/************************************************************************/
|
|
|
|
/************************************************************************/
|
|
/* SDTSRawPoint() */
|
|
/************************************************************************/
|
|
|
|
SDTSRawPoint::SDTSRawPoint()
|
|
|
|
{
|
|
nAttributes = 0;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* ~STDSRawPoint() */
|
|
/************************************************************************/
|
|
|
|
SDTSRawPoint::~SDTSRawPoint()
|
|
|
|
{
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* Read() */
|
|
/* */
|
|
/* Read a record from the passed SDTSPointReader, and assign the */
|
|
/* values from that record to this point. This is the bulk of */
|
|
/* the work in this whole file. */
|
|
/************************************************************************/
|
|
|
|
int SDTSRawPoint::Read( SDTS_IREF * poIREF, DDFRecord * poRecord )
|
|
|
|
{
|
|
/* ==================================================================== */
|
|
/* Loop over fields in this record, looking for those we */
|
|
/* recognise, and need. */
|
|
/* ==================================================================== */
|
|
for( int iField = 0; iField < poRecord->GetFieldCount(); iField++ )
|
|
{
|
|
DDFField *poField = poRecord->GetField( iField );
|
|
const char *pszFieldName;
|
|
|
|
CPLAssert( poField != NULL );
|
|
pszFieldName = poField->GetFieldDefn()->GetName();
|
|
|
|
if( EQUAL(pszFieldName,"PNTS") )
|
|
oModId.Set( poField );
|
|
|
|
else if( EQUAL(pszFieldName,"ATID") )
|
|
ApplyATID( poField );
|
|
|
|
else if( EQUAL(pszFieldName,"ARID") )
|
|
{
|
|
oAreaId.Set( poField );
|
|
}
|
|
else if( EQUAL(pszFieldName,"SADR") )
|
|
{
|
|
poIREF->GetSADR( poField, 1, &dfX, &dfY, &dfZ );
|
|
}
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* Dump() */
|
|
/************************************************************************/
|
|
|
|
void SDTSRawPoint::Dump( FILE * fp )
|
|
|
|
{
|
|
int i;
|
|
|
|
fprintf( fp, "SDTSRawPoint %s: ", oModId.GetName() );
|
|
|
|
if( oAreaId.nRecord != -1 )
|
|
fprintf( fp, " AreaId=%s", oAreaId.GetName() );
|
|
|
|
for( i = 0; i < nAttributes; i++ )
|
|
fprintf( fp, " ATID[%d]=%s", i, paoATID[i].GetName() );
|
|
|
|
fprintf( fp, " Vertex = (%.2f,%.2f,%.2f)\n", dfX, dfY, dfZ );
|
|
}
|
|
|
|
|
|
/************************************************************************/
|
|
/* ==================================================================== */
|
|
/* SDTSPointReader */
|
|
/* */
|
|
/* This is the class used to read a point module. */
|
|
/* ==================================================================== */
|
|
/************************************************************************/
|
|
|
|
/************************************************************************/
|
|
/* SDTSPointReader() */
|
|
/************************************************************************/
|
|
|
|
SDTSPointReader::SDTSPointReader( SDTS_IREF * poIREFIn )
|
|
|
|
{
|
|
poIREF = poIREFIn;
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* ~SDTSLineReader() */
|
|
/************************************************************************/
|
|
|
|
SDTSPointReader::~SDTSPointReader()
|
|
{
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* Close() */
|
|
/************************************************************************/
|
|
|
|
void SDTSPointReader::Close()
|
|
|
|
{
|
|
oDDFModule.Close();
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* Open() */
|
|
/* */
|
|
/* Open the requested line file, and prepare to start reading */
|
|
/* data records. */
|
|
/************************************************************************/
|
|
|
|
int SDTSPointReader::Open( const char * pszFilename )
|
|
|
|
{
|
|
return( oDDFModule.Open( pszFilename ) );
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* GetNextPoint() */
|
|
/* */
|
|
/* Fetch the next feature as an STDSRawPoint. */
|
|
/************************************************************************/
|
|
|
|
SDTSRawPoint * SDTSPointReader::GetNextPoint()
|
|
|
|
{
|
|
DDFRecord *poRecord;
|
|
|
|
/* -------------------------------------------------------------------- */
|
|
/* Read a record. */
|
|
/* -------------------------------------------------------------------- */
|
|
if( oDDFModule.GetFP() == NULL )
|
|
return NULL;
|
|
|
|
poRecord = oDDFModule.ReadRecord();
|
|
|
|
if( poRecord == NULL )
|
|
return NULL;
|
|
|
|
/* -------------------------------------------------------------------- */
|
|
/* Transform into a point feature. */
|
|
/* -------------------------------------------------------------------- */
|
|
SDTSRawPoint *poRawPoint = new SDTSRawPoint();
|
|
|
|
if( poRawPoint->Read( poIREF, poRecord ) )
|
|
{
|
|
return( poRawPoint );
|
|
}
|
|
else
|
|
{
|
|
delete poRawPoint;
|
|
return NULL;
|
|
}
|
|
}
|
|
|