The*_*Man 5 c++ boost boost-geometry
我有这个代码可以工作:
typedef model::point<double, 2, cs::spherical_equatorial<degree> > degree_point;
degree_point FlindersSE(-37.0, 144.0);
Run Code Online (Sandbox Code Playgroud)
和这个:
quantity<plane_angle> Flinders = 0.375 * radians; //this works 0.375 radians
Run Code Online (Sandbox Code Playgroud)
但我想做度分和秒并转换为弧度然后再转换回来。
我花了一天时间试图了解升压系统的工作原理 - 例子有点少,所以我想知道是否有人可以展示一个简单的例子?
提前致谢 8+)
编辑
//quantity<degree_base_unit> FlindersSDeg2.value(-37.0);
//quantity< angle::arcminute_base_unit> FlindersSMin = 57.0;
//quantity< angle::arcsecond_base_unit> FlindersSSec = 3.72030;
Run Code Online (Sandbox Code Playgroud)
我想我需要更好地了解声明的工作原理。:)
编辑2:
非常感谢 - 也许我花了整个时间寻找增强的方法,但那里不存在设施!我想这可能是因为我在这里发现了这个过时的代码http://www.boost.org/doc/libs/1_47_0/libs/geometry/doc/doxy/doxygen_input/sourcecode/doxygen_1.cpp
void example_dms()
{
/*
Extension, other coordinate system:
// Construction with degree/minute/seconds
boost::geometry::dms<boost::geometry::east> d1(4, 53, 32.5);
// Explicit conversion to double.
std::cout << d1.as_value() << std::endl;
// Conversion to string, with optional strings
std::cout << d1.get_dms(" deg ", " min ", " sec") << std::endl;
// Combination with latitude/longitude and cardinal directions
{
using namespace boost::geometry;
point_ll<double, boost::geometry::cs::geographic<boost::geometry::degree> > canberra(
latitude<>(dms<south>(35, 18, 27)),
longitude<>(dms<east>(149, 7, 27.9)));
std::cout << canberra << std::endl;
}
*/
}
Run Code Online (Sandbox Code Playgroud)
以下是我使用的一些升压单位和角度的转换方法:
double ToDegrees(const Angle & angle)
{
return static_cast<boost::units::quantity<boost::units::degree::plane_angle>>(angle).value();
}
double ToRadians(const Angle & angle)
{
return static_cast<boost::units::quantity<boost::units::si::plane_angle>>(angle).value();
}
Run Code Online (Sandbox Code Playgroud)
这些由类型安全工厂补充:
Angle Degrees(double angleInDegrees)
{
return angleInDegrees * boost::units::degree::degrees;
}
Angle Radians(double angleInRadians)
{
return Angle(angleInRadians * boost::units::si::radians);
}
Run Code Online (Sandbox Code Playgroud)
要捕获度、分、秒,请将上面的度双精度替换为转换结构,如下所示:
struct DMS
{
DMS(double value)
{
degrees = std::floor(value);
double rem = (value-degrees) * 60;
minutes = std::floor(rem);
seconds = (rem-minutes) * 60;
}
operator double() const
{
return degrees + minutes/60 + seconds/3600;
}
double degrees;
double minutes;
double seconds;
};
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5086 次 |
| 最近记录: |