| | |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| |
|
| | #include <TopExp_Explorer.hxx> |
| | #include <TopoDS.hxx> |
| | #include <TopoDS_Edge.hxx> |
| | #include <TopoDS_Wire.hxx> |
| | #include <BRepAdaptor_Curve.hxx> |
| | #include <BRepLProp_CLProps.hxx> |
| |
|
| | #include <App/Application.h> |
| | #include <App/Document.h> |
| | #include <App/MeasureManager.h> |
| |
|
| | #include <Mod/Part/App/PartFeature.h> |
| |
|
| | #include "MeasureRadius.h" |
| |
|
| |
|
| | using namespace Measure; |
| |
|
| | PROPERTY_SOURCE(Measure::MeasureRadius, Measure::MeasureBase) |
| |
|
| |
|
| | MeasureRadius::MeasureRadius() |
| | { |
| | ADD_PROPERTY_TYPE(Element, (nullptr), "Measurement", App::Prop_None, "Element to get the radius from"); |
| | Element.setScope(App::LinkScope::Global); |
| | Element.setAllowExternal(true); |
| |
|
| | ADD_PROPERTY_TYPE( |
| | Radius, |
| | (0.0), |
| | "Measurement", |
| | App::PropertyType(App::Prop_ReadOnly | App::Prop_Output), |
| | "Radius of selection" |
| | ); |
| | } |
| |
|
| | MeasureRadius::~MeasureRadius() = default; |
| |
|
| | |
| | |
| | |
| | bool MeasureRadius::isValidSelection(const App::MeasureSelection& selection) |
| | { |
| |
|
| | if (selection.empty() || selection.size() > 1) { |
| | |
| | return false; |
| | } |
| |
|
| | auto element = selection.front(); |
| | auto type = App::MeasureManager::getMeasureElementType(element); |
| |
|
| | if (type == App::MeasureElementType::INVALID) { |
| | return false; |
| | } |
| |
|
| | if (type != App::MeasureElementType::CIRCLE && type != App::MeasureElementType::ARC) { |
| | return false; |
| | } |
| |
|
| | return true; |
| | } |
| |
|
| | |
| | |
| | bool MeasureRadius::isPrioritizedSelection(const App::MeasureSelection& selection) |
| | { |
| | if (selection.size() != 1) { |
| | return false; |
| | } |
| |
|
| | auto element = selection.front(); |
| | auto type = App::MeasureManager::getMeasureElementType(element); |
| |
|
| | if (type == App::MeasureElementType::CIRCLE || type == App::MeasureElementType::ARC) { |
| | return true; |
| | } |
| |
|
| | return false; |
| | } |
| |
|
| |
|
| | |
| | void MeasureRadius::parseSelection(const App::MeasureSelection& selection) |
| | { |
| | auto element = selection.front(); |
| | auto objT = element.object; |
| |
|
| | std::vector<std::string> subElementList {objT.getSubName()}; |
| | Element.setValue(objT.getObject(), subElementList); |
| | } |
| |
|
| |
|
| | App::DocumentObjectExecReturn* MeasureRadius::execute() |
| | { |
| | auto info = getMeasureInfoFirst(); |
| | if (!info || !info->valid) { |
| | return new App::DocumentObjectExecReturn("Cannot calculate radius"); |
| | } |
| |
|
| | Radius.setValue(info->radius); |
| | return DocumentObject::StdReturn; |
| | } |
| |
|
| |
|
| | void MeasureRadius::onChanged(const App::Property* prop) |
| | { |
| | if (isRestoring() || isRemoving()) { |
| | return; |
| | } |
| |
|
| | if (prop == &Element) { |
| | auto ret = recompute(); |
| | delete ret; |
| | } |
| |
|
| | MeasureBase::onChanged(prop); |
| | } |
| |
|
| |
|
| | |
| | Base::Placement MeasureRadius::getPlacement() const |
| | { |
| | auto loc = getMeasureInfoFirst()->pointOnCurve; |
| | auto p = Base::Placement(); |
| | p.setPosition(loc); |
| | return p; |
| | } |
| |
|
| |
|
| | |
| | Base::Vector3d MeasureRadius::getPointOnCurve() const |
| | { |
| | return getMeasureInfoFirst()->pointOnCurve; |
| | } |
| |
|
| | |
| | Part::MeasureRadiusInfoPtr MeasureRadius::getMeasureInfoFirst() const |
| | { |
| | const App::DocumentObject* object = Element.getValue(); |
| | const std::vector<std::string>& subElements = Element.getSubValues(); |
| |
|
| | if (!object || subElements.empty()) { |
| | |
| | return std::make_shared<Part::MeasureRadiusInfo>(); |
| | } |
| |
|
| | App::SubObjectT subject {object, subElements.front().c_str()}; |
| | auto info = getMeasureInfo(subject); |
| | if (!info || !info->valid) { |
| | |
| | return std::make_shared<Part::MeasureRadiusInfo>(); |
| | } |
| |
|
| | auto radiusInfo = std::dynamic_pointer_cast<Part::MeasureRadiusInfo>(info); |
| | return radiusInfo; |
| | } |
| |
|
| | |
| | |
| | std::vector<App::DocumentObject*> MeasureRadius::getSubject() const |
| | { |
| | return {Element.getValue()}; |
| | } |
| |
|