Sketcher: Extend ViewProviderSketchGeometryExtension to hold the VisualLayerId

==============================================================================

In the Layers implementation there are User Layers, which have no direct impact on visualisation,
and allow to group conceptually related geometry into logical entities, and Visual Layers, which
define how geometries are visualised (or even whether they are visualised or not).

For User Layers, SketchObject is responsible for the definition of the layers, and SketcherGeometryExtension
is responsible for indicating the User Layer to which a geometry belongs (via a LayerId field).

For Visual Layers, ViewProviderSketch is responsible for the definition of the visual layers, and
ViewProviderSketchGeometryExtension is responsible for indicating the visual layer to which a geometry belongs.

With this commit, ViewProviderSketchGeometryExtension:
- takes over the responsibility of carrying a visual layer Id.
- is extended to be persistent and serialise the Id.
- is extended to be accesible from Python.
This commit is contained in:
Abdullah Tahiri
2023-02-28 07:12:50 +01:00
committed by abdullahtahiriyo
parent a7c37aacb0
commit 873e34cd6e
6 changed files with 168 additions and 9 deletions

View File

@@ -37,6 +37,7 @@
#include "ViewProviderPython.h"
#include "ViewProviderSketch.h"
#include "ViewProviderSketchGeometryExtension.h"
#include "ViewProviderSketchGeometryExtensionPy.h"
#include "Workbench.h"
@@ -93,7 +94,7 @@ PyMOD_INIT_FUNC(SketcherGui)
PyMOD_Return(nullptr);
}
PyObject* mod = SketcherGui::initModule();
PyObject* sketcherGuiModule = SketcherGui::initModule();
Base::Console().Log("Loading GUI of Sketcher module... done\n");
Gui::BitmapFactory().addPath(QString::fromLatin1(":/icons/constraints"));
@@ -116,6 +117,9 @@ PyMOD_INIT_FUNC(SketcherGui)
SketcherGui::Workbench::init();
// Add Types to module
Base::Interpreter().addType(&SketcherGui::ViewProviderSketchGeometryExtensionPy ::Type,sketcherGuiModule,"ViewProviderSketchGeometryExtension");
// init objects
SketcherGui::ViewProviderSketch ::init();
SketcherGui::ViewProviderPython ::init();
@@ -124,7 +128,7 @@ PyMOD_INIT_FUNC(SketcherGui)
SketcherGui::SoDatumLabel ::initClass();
SketcherGui::SoZoomTranslation ::initClass();
SketcherGui::PropertyConstraintListItem ::init();
SketcherGui::ViewProviderSketchGeometryExtension ::init();
SketcherGui::ViewProviderSketchGeometryExtension ::init();
(void)new Gui::PrefPageProducer<SketcherGui::SketcherSettings> ( QT_TRANSLATE_NOOP("QObject","Sketcher") );
(void)new Gui::PrefPageProducer<SketcherGui::SketcherSettingsGrid> ( QT_TRANSLATE_NOOP("QObject","Sketcher") );
@@ -134,5 +138,5 @@ PyMOD_INIT_FUNC(SketcherGui)
// add resources and reloads the translators
loadSketcherResource();
PyMOD_Return(mod);
PyMOD_Return(sketcherGuiModule);
}

View File

@@ -27,6 +27,8 @@ set(SketcherGui_LIBS
qt_add_resources(SketcherGui_SRCS Resources/Sketcher.qrc)
generate_from_xml(ViewProviderSketchGeometryExtensionPy)
set(SketcherGui_UIC_SRCS
TaskSketcherConstraints.ui
TaskSketcherElements.ui
@@ -152,6 +154,17 @@ SET(SketcherGui_SRCS
ViewProviderSketchGeometryExtension.cpp
)
SET(Python_SRCS
ViewProviderSketchGeometryExtensionPy.xml
ViewProviderSketchGeometryExtensionPyImp.cpp
)
SOURCE_GROUP("Python" FILES ${Python_SRCS})
SET(SketcherGui_SRCS
${SketcherGui_SRCS}
${Python_SRCS}
)
if(FREECAD_USE_PCH)
add_definitions(-D_PreComp_)
GET_MSVC_PRECOMPILED_SOURCE("PreCompiled.cpp" PCH_SRCS ${SketcherGui_SRCS})

View File

@@ -23,6 +23,10 @@
#include "PreCompiled.h"
#include <Base/Exception.h>
#include <Base/Reader.h>
#include <Base/Writer.h>
#include <Mod/Sketcher/Gui/ViewProviderSketchGeometryExtensionPy.h>
#include "ViewProviderSketchGeometryExtension.h"
@@ -30,10 +34,10 @@
using namespace SketcherGui;
//---------- Geometry Extension
TYPESYSTEM_SOURCE(SketcherGui::ViewProviderSketchGeometryExtension,Part::GeometryExtension)
TYPESYSTEM_SOURCE(SketcherGui::ViewProviderSketchGeometryExtension,Part::GeometryPersistenceExtension)
ViewProviderSketchGeometryExtension::ViewProviderSketchGeometryExtension():RepresentationFactor(1.0)
ViewProviderSketchGeometryExtension::ViewProviderSketchGeometryExtension():RepresentationFactor(1.0), VisualLayerId(0)
{
}
@@ -42,6 +46,7 @@ void ViewProviderSketchGeometryExtension::copyAttributes(Part::GeometryExtension
{
Part::GeometryExtension::copyAttributes(cpy);
static_cast<ViewProviderSketchGeometryExtension *>(cpy)->RepresentationFactor = this->RepresentationFactor;
static_cast<ViewProviderSketchGeometryExtension *>(cpy)->VisualLayerId = this->VisualLayerId;
}
std::unique_ptr<Part::GeometryExtension> ViewProviderSketchGeometryExtension::copy() const
@@ -57,7 +62,23 @@ std::unique_ptr<Part::GeometryExtension> ViewProviderSketchGeometryExtension::co
#endif
}
void ViewProviderSketchGeometryExtension::restoreAttributes(Base::XMLReader &reader)
{
Part::GeometryPersistenceExtension::restoreAttributes(reader);
if(reader.hasAttribute("visualLayerId"))
VisualLayerId = reader.getAttributeAsInteger("visualLayerId");
}
void ViewProviderSketchGeometryExtension::saveAttributes(Base::Writer &writer) const
{
Part::GeometryPersistenceExtension::saveAttributes(writer);
writer.Stream() << "\" visualLayerId=\"" << VisualLayerId;
}
PyObject * ViewProviderSketchGeometryExtension::getPyObject()
{
THROWM(Base::NotImplementedError, "ViewProviderSketchGeometryExtension does not have a Python counterpart");
return new ViewProviderSketchGeometryExtensionPy(new ViewProviderSketchGeometryExtension(*this));
}

View File

@@ -29,7 +29,7 @@
namespace SketcherGui {
class SketcherGuiExport ViewProviderSketchGeometryExtension : public Part::GeometryExtension
class SketcherGuiExport ViewProviderSketchGeometryExtension : public Part::GeometryPersistenceExtension
{
TYPESYSTEM_HEADER_WITH_OVERRIDE();
public:
@@ -49,17 +49,23 @@ public:
// Applicability: General abstract concepts embodied in a geometry, in practice B-Spline poles.
// Why not in SketchGeometryExtension? Because it is merely representation related. It has no place in
// a console application.
virtual double getRepresentationFactor() const {return RepresentationFactor;}
virtual void setRepresentationFactor(double representationFactor) {RepresentationFactor = representationFactor;}
double getRepresentationFactor() const {return RepresentationFactor;}
void setRepresentationFactor(double representationFactor) {RepresentationFactor = representationFactor;}
int getVisualLayerId() const {return VisualLayerId;}
void setVisualLayerId(int visuallayerid) {VisualLayerId = visuallayerid;}
protected:
void copyAttributes(Part::GeometryExtension * cpy) const override;
void restoreAttributes(Base::XMLReader &reader) override;
void saveAttributes(Base::Writer &writer) const override;
private:
ViewProviderSketchGeometryExtension(const ViewProviderSketchGeometryExtension&) = default;
private:
double RepresentationFactor;
int VisualLayerId;
};
} //namespace SketcherGui

View File

@@ -0,0 +1,27 @@
<?xml version="1.0" encoding="UTF-8"?>
<GenerateModel xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="generateMetaModel_Module.xsd">
<PythonExport
Father="GeometryExtensionPy"
Name="ViewProviderSketchGeometryExtensionPy"
PythonName="SketcherGui.ViewProviderSketchGeometryExtension"
Twin="ViewProviderSketchGeometryExtension"
TwinPointer="ViewProviderSketchGeometryExtension"
Include="Mod/Sketcher/Gui/ViewProviderSketchGeometryExtension.h"
Namespace="SketcherGui"
FatherInclude="Mod/Part/App/GeometryExtensionPy.h"
FatherNamespace="Part"
Constructor="true">
<Documentation>
<Author Licence="LGPL" Name="Abdullah Tahiri" EMail="abdullah.tahiri.yo@gmail.com" />
<UserDocu>Describes a ViewProviderSketchGeometryExtension</UserDocu>
</Documentation>
<Attribute Name="VisualLayerId" ReadOnly="false">
<Documentation>
<UserDocu>
Sets/returns this geometry's Visual Layer Id.
</UserDocu>
</Documentation>
<Parameter Name="VisualLayerId" Type="Long"/>
</Attribute>
</PythonExport>
</GenerateModel>

View File

@@ -0,0 +1,88 @@
/***************************************************************************
* Copyright (c) 2023 Abdullah Tahiri <abdullah.tahiri.yo@gmail.com> *
* *
* This file is part of the FreeCAD CAx development system. *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This library is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this library; see the file COPYING.LIB. If not, *
* write to the Free Software Foundation, Inc., 59 Temple Place, *
* Suite 330, Boston, MA 02111-1307, USA *
* *
***************************************************************************/
#include "PreCompiled.h"
#include "ViewProviderSketchGeometryExtensionPy.h"
#include "ViewProviderSketchGeometryExtensionPy.cpp"
using namespace SketcherGui;
// returns a string which represents the object e.g. when printed in python
std::string ViewProviderSketchGeometryExtensionPy::representation() const
{
std::stringstream str;
str << "<ViewProviderSketchGeometryExtension ( VisualLayerId=";
str << getViewProviderSketchGeometryExtensionPtr()->getVisualLayerId() << "\") >";
return str.str();
}
PyObject *ViewProviderSketchGeometryExtensionPy::PyMake(struct _typeobject *, PyObject *, PyObject *) // Python wrapper
{
// create a new instance of PointPy and the Twin object
return new ViewProviderSketchGeometryExtensionPy(new ViewProviderSketchGeometryExtension);
}
// constructor method
int ViewProviderSketchGeometryExtensionPy::PyInit(PyObject* args, PyObject* /*kwd*/)
{
if (PyArg_ParseTuple(args, "")) {
// default extension
return 0;
}
PyErr_Clear();
int VisualLayerId;
if (PyArg_ParseTuple(args, "i", &VisualLayerId)) {
this->getViewProviderSketchGeometryExtensionPtr()->setVisualLayerId(VisualLayerId);
return 0;
}
PyErr_SetString(PyExc_TypeError, "ViewProviderSketchGeometryExtension constructor accepts:\n"
"-- empty parameter list\n"
"-- int\n");
return -1;
}
Py::Long ViewProviderSketchGeometryExtensionPy::getVisualLayerId() const
{
return Py::Long(this->getViewProviderSketchGeometryExtensionPtr()->getVisualLayerId());
}
void ViewProviderSketchGeometryExtensionPy::setVisualLayerId(Py::Long Id)
{
this->getViewProviderSketchGeometryExtensionPtr()->setVisualLayerId(Id);
}
PyObject *ViewProviderSketchGeometryExtensionPy::getCustomAttributes(const char* /*attr*/) const
{
return nullptr;
}
int ViewProviderSketchGeometryExtensionPy::setCustomAttributes(const char* /*attr*/, PyObject* /*obj*/)
{
return 0;
}