本文整理汇总了C++中ossimDpt类的典型用法代码示例。如果您正苦于以下问题:C++ ossimDpt类的具体用法?C++ ossimDpt怎么用?C++ ossimDpt使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了ossimDpt类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: lineSampleToWorld
//*****************************************************************************
// METHOD: ossimRpcModel::lineSampleToWorld()
//
// Overrides base class implementation. Performs DEM intersection.
//*****************************************************************************
void ossimRpcModel::lineSampleToWorld(const ossimDpt& imagePoint,
ossimGpt& worldPoint) const
{
//---
// Under debate... (drb 20130610)
// this seems to be more accurate for the round trip
//---
#if 0
if(!imagePoint.hasNans())
{
lineSampleHeightToWorld(imagePoint,
worldPoint.height(),
worldPoint);
}
else
{
worldPoint.makeNan();
}
#else
if(!imagePoint.hasNans())
{
ossimEcefRay ray;
imagingRay(imagePoint, ray);
ossimElevManager::instance()->intersectRay(ray, worldPoint);
}
else
{
worldPoint.makeNan();
}
#endif
}
示例2: shift
//*******************************************************************
// Public Method: ossimDrect::clip
//*******************************************************************
bool ossimDrect::clip(ossimDpt &p1, ossimDpt &p2)const
{
if(p1.isNan() || p2.isNan())
{
return false;
}
ossimDpt shift(-theUlCorner.x,
-theUlCorner.y);
ossimDpt tempShiftP1 = p1+shift;
ossimDpt tempShiftP2 = p2+shift;
double maxW = width()-1;
double maxH = height()-1;
if (clip_1d (&tempShiftP1.x, &tempShiftP1.y,
&tempShiftP2.x, &tempShiftP2.y,
maxW) == 0)
{
return false;
}
if(clip_1d (&tempShiftP1.y,
&tempShiftP1.x,
&tempShiftP2.y,
&tempShiftP2.x, maxH) == 0)
{
return false;
}
p1 = tempShiftP1-shift;
p2 = tempShiftP2-shift;
return true;
}
示例3: theOrientMode
ossimDrect::ossimDrect(const ossimDpt& p1,
const ossimDpt& p2,
const ossimDpt& p3,
const ossimDpt& p4,
ossimCoordSysOrientMode mode)
: theOrientMode(mode)
{
if(p1.hasNans()||p2.hasNans()||p3.hasNans()||p4.hasNans())
{
makeNan();
}
else
{
double minx, miny;
double maxx, maxy;
minx = std::min( p1.x, std::min(p2.x, std::min(p3.x, p4.x)));
miny = std::min( p1.y, std::min(p2.y, std::min(p3.y, p4.y)));
maxx = std::max( p1.x, std::max(p2.x, std::max(p3.x, p4.x)));
maxy = std::max( p1.y, std::max(p2.y, std::max(p3.y, p4.y)));
if(mode == OSSIM_LEFT_HANDED)
{
*this = ossimDrect(minx, miny, maxx, maxy, mode);
}
else
{
*this = ossimDrect(minx,maxy, maxx, miny, mode);
}
}
}
示例4: sceneToLocal
ossimDpt ImageViewManipulator::sceneToLocal(const ossimDpt& scenePoint)
{
ossimDpt result;
result.makeNan();
ossimImageGeometry* geom = asGeometry();
if(geom)
{
ossimGpt wpt;
geom->localToWorld(scenePoint, wpt);
result = wpt;
}
else
{
ossimImageViewAffineTransform* ivat = getObjectAs<ossimImageViewAffineTransform>();
if(ivat)
{
if(!scenePoint.hasNans())
{
ivat->viewToImage(scenePoint, result);
}
}
}
return result;
}
示例5: lineSampleToWorld
void ossimBuckeyeSensor::lineSampleToWorld(const ossimDpt& image_point,
ossimGpt& gpt) const
{
if (traceDebug()) ossimNotify(ossimNotifyLevel_DEBUG) << "DEBUG ossimBuckeyeSensor::lineSampleToWorld:entering..." << std::endl;
if(image_point.hasNans())
{
gpt.makeNan();
return;
}
//***
// Determine imaging ray and invoke elevation source object's services to
// intersect ray with terrain model:
//***
ossimEcefRay ray;
imagingRay(image_point, ray);
ossimElevManager::instance()->intersectRay(ray, gpt);
if (traceDebug())
{
ossimNotify(ossimNotifyLevel_DEBUG) << "image_point = " << image_point << std::endl;
ossimNotify(ossimNotifyLevel_DEBUG) << "ray = " << ray << std::endl;
ossimNotify(ossimNotifyLevel_DEBUG) << "gpt = " << gpt << std::endl;
}
if (traceDebug()) ossimNotify(ossimNotifyLevel_DEBUG) << "DEBUG ossimBuckeyeSensor::lineSampleToWorld: returning..." << std::endl;
return;
}
示例6: init
bool ossimGpkgTileMatrixRecord::init( ossim_int32 zoom_level,
const ossimIpt& matrixSize,
const ossimIpt& tileSize,
const ossimDpt& gsd )
{
bool status = false;
if ( (matrixSize.hasNans() == false) && (tileSize.hasNans() == false) &&
(gsd.hasNans() == false) )
{
m_table_name = "tiles";
m_zoom_level = zoom_level;
m_matrix_width = matrixSize.x;
m_matrix_height = matrixSize.y;
m_tile_width = tileSize.x;
m_tile_height = tileSize.y;
m_pixel_x_size = gsd.x;
m_pixel_y_size = gsd.y;
status = true;
}
return status;
} // End: ossimGpkgTileMatrixRecord::init( zoom_level, ... )
示例7: init
bool ossimGpkgTileMatrixSetRecord::init(
const std::string& tableName,ossim_int32 srs_id,
const ossimDpt& minPt, const ossimDpt& maxPt )
{
bool status = false;
if ( (minPt.hasNans() == false) && (maxPt.hasNans() == false) )
{
m_table_name = tableName;
m_srs_id = srs_id;
m_min_x = minPt.x;
m_min_y = minPt.y;
m_max_x = maxPt.x;
m_max_y = maxPt.y;
status = true;
}
return status;
}
示例8: imageToView
void ossimIvtGeomXform::imageToView(const ossimDpt& ipt, ossimDpt& viewPt)
{
viewPt.makeNan();
if(m_ivt.valid())
{
m_ivt->imageToView(ipt, viewPt);
}
}
示例9: groundToImage
void ossimIvtGeomXform::groundToImage(const ossimGpt& gpt, ossimDpt& ipt)
{
ipt.makeNan();
if(m_geom.valid())
{
m_geom->worldToLocal(gpt, ipt);
}
}
示例10: viewToImage
void ossimIvtGeomXform::viewToImage(const ossimDpt& viewPt, ossimDpt& ipt)
{
ipt.makeNan();
if(m_ivt.valid())
{
m_ivt->viewToImage(viewPt, ipt);
}
}
示例11: worldToLineSample
//*****************************************************************************
// METHOD: ossimRpcProjection::worldToLineSample()
//
// Overrides base class implementation. Directly computes line-sample from
// the polynomials.
//*****************************************************************************
void ossimRpcProjection::worldToLineSample(const ossimGpt& ground_point,
ossimDpt& imgPt) const
{
if (traceExec()) ossimNotify(ossimNotifyLevel_DEBUG) << "DEBUG ossimRpcProjection::worldToLineSample(): entering..." << std::endl;
if(ground_point.isLatNan() ||
ground_point.isLonNan() )
{
imgPt.makeNan();
return;
}
//*
// Normalize the lat, lon, hgt:
//*
double nlat = (ground_point.lat - theLatOffset) / theLatScale;
double nlon = (ground_point.lon - theLonOffset) / theLonScale;
double nhgt;
if(ossim::isnan(ground_point.hgt))
{
nhgt = (theHgtScale - theHgtOffset) / theHgtScale;
}
else
{
nhgt = (ground_point.hgt - theHgtOffset) / theHgtScale;
}
//***
// Compute the adjusted, normalized line (U) and sample (V):
//***
double Pu = polynomial(nlat, nlon, nhgt, theLineNumCoef);
double Qu = polynomial(nlat, nlon, nhgt, theLineDenCoef);
double Pv = polynomial(nlat, nlon, nhgt, theSampNumCoef);
double Qv = polynomial(nlat, nlon, nhgt, theSampDenCoef);
double U_rot = Pu / Qu;
double V_rot = Pv / Qv;
//***
// U, V are normalized quantities. Need now to establish the image file
// line and sample. First, back out the adjustable parameter effects
// starting with rotation:
//***
double U = U_rot*theCosMapRot + V_rot*theSinMapRot;
double V = V_rot*theCosMapRot - U_rot*theSinMapRot;
//***
// Now back out skew, scale, and offset adjustments:
//***
imgPt.line = U*(theLineScale+theIntrackScale) + theLineOffset + theIntrackOffset;
imgPt.samp = V*(theSampScale+theCrtrackScale) + theSampOffset + theCrtrackOffset;
if (traceExec()) ossimNotify(ossimNotifyLevel_DEBUG) << "DEBUG ossimRpcProjection::worldToLineSample(): returning..." << std::endl;
return;
}
示例12: x
//*******************************************************************
// Public Constructor:
//*******************************************************************
ossimFpt::ossimFpt(const ossimDpt& pt)
:
x(pt.x), y(pt.y)
{
if(pt.hasNans())
{
makeNan();
}
}
示例13: getDecimationFactor
void ossimImageSourceSequencer::getDecimationFactor(ossim_uint32 resLevel,
ossimDpt& result) const
{
if(theInputConnection)
{
theInputConnection->getDecimationFactor(resLevel, result);
}
result.makeNan();
}
示例14: groundToView
void ossimIvtGeomXform::groundToView(const ossimGpt& gpt, ossimDpt& viewPt)
{
ossimDpt ipt;
viewPt.makeNan();
groundToImage(gpt, ipt);
if(!ipt.hasNans())
{
imageToView(ipt, viewPt);
}
}
示例15: viewToImage
//*****************************************************************************
// Other workhorse of the object. Converts view-space to image-space.
//*****************************************************************************
void ossimImageViewProjectionTransform::viewToImage(const ossimDpt& vp, ossimDpt& ip) const
{
// Check for same geometries on input and output (this includes NULL geoms):
if (m_imageGeometry == m_viewGeometry)
{
ip = vp;
return;
}
// Otherwise we need access to good geoms. Check for a bad geometry object:
if (!m_imageGeometry || !m_viewGeometry)
{
ip.makeNan();
return;
}
// Check for same projection on input and output sides to save projection to ground:
const ossimProjection* iproj = m_imageGeometry->getProjection();
const ossimProjection* vproj = m_viewGeometry->getProjection();
if ((iproj && vproj && iproj->isEqualTo(*vproj)) || (iproj == vproj))
{
// Check for possible same 2D transforms as well:
const ossim2dTo2dTransform* ixform = m_imageGeometry->getTransform();
const ossim2dTo2dTransform* vxform = m_viewGeometry->getTransform();
if (((ixform && vxform && ixform->isEqualTo(*vxform)) || (ixform == vxform)) &&
(m_imageGeometry->decimationFactor(0) == m_viewGeometry->decimationFactor(0)))
{
ip = vp;
return;
}
// Not the same 2D transform, so just perform local-image -> full-image -> local-view:
ossimDpt fp;
m_viewGeometry->rnToFull(vp, 0, fp);
m_imageGeometry->fullToRn(fp, 0, ip);
return;
}
//---
// Completely different left and right side geoms (typical situation).
// Need to project to ground.
//---
ossimGpt gp;
m_viewGeometry->localToWorld(vp, gp);
m_imageGeometry->worldToLocal(gp, ip);
#if 0 /* Please leave for debug. */
cout <<"DEBUG ossimImageViewProjectionTransform::viewToImage:"
<<"\n vp: "<<vp
<<"\n gp: "<<gp
<<"\n ip: "<<ip
<<std::endl;
#endif
}