我们看下src/Mod/Fem/Gui/ViewProviderFemMesh.cpp, 其中有个applyDisplacementToNodes函数:
Code: Select all
void ViewProviderFemMesh::applyDisplacementToNodes(double factor)
{
if(DisplacementVector.size() == 0)
return;
float x,y,z;
// set the point coordinates
long sz = pcCoords->point.getNum();
SbVec3f* verts = pcCoords->point.startEditing();
for (long i=0;i < sz ;i++) {
verts[i].getValue(x,y,z);
// undo old factor#
Base::Vector3d oldDisp = DisplacementVector[i] * DisplacementFactor;
x -= oldDisp.x;
y -= oldDisp.y;
z -= oldDisp.z;
// apply new factor
Base::Vector3d newDisp = DisplacementVector[i] * factor;
x += newDisp.x;
y += newDisp.y;
z += newDisp.z;
// set the new value
verts[i].setValue(x,y,z);
}Gui/
pcCoords->point.finishEditing();
DisplacementFactor = factor;
}
Code: Select all
PyObject* ViewProviderFemMeshPy::applyDisplacement(PyObject * args)
{
double factor;
if (!PyArg_ParseTuple(args, "d", &factor))
return 0;
this->getViewProviderFemMeshPtr()->applyDisplacementToNodes(factor);
Py_Return;
}
python中对这个函数的调用可以看femguiobjects\_ViewProviderFemResultMechanical.py:
Code: Select all
def update_displacement(self, factor=None):
if factor is None:
if FreeCAD.FEM_dialog["show_disp"]:
factor = self.result_widget.sb_displacement_factor.value()
else:
factor = 0.0
self.mesh_obj.ViewObject.applyDisplacement(factor)