200 строки
8.0 KiB
C++
200 строки
8.0 KiB
C++
/******************************************************************************
|
|
*
|
|
* 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"
|
|
|
|
/************************************************************************/
|
|
/* ==================================================================== */
|
|
/* SDTSRawPoint */
|
|
/* */
|
|
/* This is a simple class for holding the data related with a */
|
|
/* point feature. */
|
|
/* ==================================================================== */
|
|
/************************************************************************/
|
|
|
|
/************************************************************************/
|
|
/* SDTSRawPoint() */
|
|
/************************************************************************/
|
|
|
|
SDTSRawPoint::SDTSRawPoint() : dfX(0.0), dfY(0.0), dfZ(0.0)
|
|
{
|
|
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);
|
|
if (poField == nullptr)
|
|
return FALSE;
|
|
DDFFieldDefn *poFieldDefn = poField->GetFieldDefn();
|
|
if (poFieldDefn == nullptr)
|
|
return FALSE;
|
|
|
|
const char *pszFieldName = poFieldDefn->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)
|
|
|
|
{
|
|
fprintf(fp, "SDTSRawPoint %s: ", oModId.GetName());
|
|
|
|
if (oAreaId.nRecord != -1)
|
|
fprintf(fp, " AreaId=%s", oAreaId.GetName());
|
|
|
|
for (int 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()
|
|
|
|
{
|
|
/* -------------------------------------------------------------------- */
|
|
/* Read a record. */
|
|
/* -------------------------------------------------------------------- */
|
|
if (oDDFModule.GetFP() == nullptr)
|
|
return nullptr;
|
|
|
|
DDFRecord *poRecord = oDDFModule.ReadRecord();
|
|
|
|
if (poRecord == nullptr)
|
|
return nullptr;
|
|
|
|
/* -------------------------------------------------------------------- */
|
|
/* Transform into a point feature. */
|
|
/* -------------------------------------------------------------------- */
|
|
SDTSRawPoint *poRawPoint = new SDTSRawPoint();
|
|
|
|
if (poRawPoint->Read(poIREF, poRecord))
|
|
{
|
|
return poRawPoint;
|
|
}
|
|
|
|
delete poRawPoint;
|
|
return nullptr;
|
|
}
|