[TD]Fix RichText parent in scene (fix #18283) (#18768)

* [TD]allow DrawViewAnno to be attached to another view

* [TD]allow image and spreadsheet attach to view

* [TD]ensure correct parent in scene

* [TD]refactor command helpers to separate file

- gathering the helpers in one place
- helper redundancy to be address in another change

* [TD]create symbol, spreadsheet, image with parent

* [TD]fix claimChildren for some views

- also includes many lint fixes
This commit is contained in:
WandererFan
2025-01-06 12:11:25 -05:00
committed by GitHub
parent f4b1ccdc54
commit 91d7c875a5
25 changed files with 698 additions and 272 deletions

View File

@@ -40,6 +40,8 @@
#include <Gui/ViewProviderDocumentObject.h>
#include <Mod/TechDraw/App/LineGroup.h>
#include <Mod/TechDraw/App/DrawRichAnno.h>
#include <Mod/TechDraw/App/DrawLeaderLine.h>
#include "PreferencesGui.h"
#include "ZVALUE.h"
@@ -72,9 +74,6 @@ ViewProviderBalloon::ViewProviderBalloon()
StackOrder.setValue(ZVALUE::DIMENSION);
}
ViewProviderBalloon::~ViewProviderBalloon()
{
}
bool ViewProviderBalloon::doubleClicked()
{
@@ -84,7 +83,7 @@ bool ViewProviderBalloon::doubleClicked()
void ViewProviderBalloon::setupContextMenu(QMenu* menu, QObject* receiver, const char* member)
{
Gui::ActionFunction* func = new Gui::ActionFunction(menu);
auto* func = new Gui::ActionFunction(menu);
QAction* act = menu->addAction(QObject::tr("Edit %1").arg(QString::fromUtf8(getObject()->Label.getValue())));
act->setData(QVariant((int)ViewProvider::Default));
func->trigger(act, [this]() {
@@ -111,12 +110,12 @@ bool ViewProviderBalloon::setEdit(int ModNum)
return true;
}
void ViewProviderBalloon::updateData(const App::Property* p)
void ViewProviderBalloon::updateData(const App::Property* prop)
{
//Balloon handles X, Y updates differently that other QGIView
//call QGIViewBalloon::updateView
if (p == &(getViewObject()->X) ||
p == &(getViewObject()->Y) ){
if (prop == &(getViewObject()->X) ||
prop == &(getViewObject()->Y) ){
QGIView* qgiv = getQView();
if (qgiv) {
qgiv->updateView(true);
@@ -124,22 +123,22 @@ void ViewProviderBalloon::updateData(const App::Property* p)
}
//Skip QGIView X, Y processing - do not call ViewProviderDrawingView
Gui::ViewProviderDocumentObject::updateData(p);
Gui::ViewProviderDocumentObject::updateData(prop);
}
void ViewProviderBalloon::onChanged(const App::Property* p)
void ViewProviderBalloon::onChanged(const App::Property* prop)
{
if ((p == &Font) ||
(p == &Fontsize) ||
(p == &Color) ||
(p == &LineWidth) ||
(p == &LineVisible)) {
if ((prop == &Font) ||
(prop == &Fontsize) ||
(prop == &Color) ||
(prop == &LineWidth) ||
(prop == &LineVisible)) {
QGIView* qgiv = getQView();
if (qgiv) {
qgiv->updateView(true);
}
}
Gui::ViewProviderDocumentObject::onChanged(p);
Gui::ViewProviderDocumentObject::onChanged(prop);
}
TechDraw::DrawViewBalloon* ViewProviderBalloon::getViewObject() const
@@ -189,3 +188,24 @@ bool ViewProviderBalloon::onDelete(const std::vector<std::string> & parms)
}
return true;
}
std::vector<App::DocumentObject*> ViewProviderBalloon::claimChildren() const
{
// What can reasonably have a Balloon as a parent? A leader? a bit unconventional, but not forbidden.
// A RichAnno? Maybe? Another Balloon? Maybe?
std::vector<App::DocumentObject*> temp;
const std::vector<App::DocumentObject*>& candidates = getViewObject()->getInList();
for (auto& obj : candidates) {
if (obj->isDerivedFrom<TechDraw::DrawViewBalloon>() ||
obj->isDerivedFrom<TechDraw::DrawLeaderLine>() ||
obj->isDerivedFrom<TechDraw::DrawRichAnno>() ) {
temp.push_back(obj);
}
}
return temp;
}