112 lines
5.0 KiB
C++
112 lines
5.0 KiB
C++
/***************************************************************************
|
|
* Copyright (c) 2010 Juergen Riegel <FreeCAD@juergen-riegel.net> *
|
|
* *
|
|
* 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 <Mod/Part/App/FCBRepAlgoAPI_Fuse.h>
|
|
#include <Precision.hxx>
|
|
#include <TopExp_Explorer.hxx>
|
|
#include <TopoDS.hxx>
|
|
#include <TopoDS_Face.hxx>
|
|
|
|
|
|
#include <App/DocumentObject.h>
|
|
#include <Base/Console.h>
|
|
#include <Base/Exception.h>
|
|
|
|
#include "FeaturePad.h"
|
|
|
|
using namespace PartDesign;
|
|
|
|
// Note, TwoLengths has been deprecated by #21794. We do not remove it from the ui
|
|
// because the files store the enum index. So it is not possible to migrate files if the
|
|
// enum entry is removed (see #23612). In the distant future, when all files are reasonably
|
|
// migrated we can drop this.
|
|
const char* Pad::TypeEnums[]
|
|
= {"Length", "UpToLast", "UpToFirst", "UpToFace", "?TwoLengths", "UpToShape", nullptr};
|
|
|
|
PROPERTY_SOURCE(PartDesign::Pad, PartDesign::FeatureExtrude)
|
|
|
|
Pad::Pad()
|
|
{
|
|
addSubType = FeatureAddSub::Additive;
|
|
|
|
ADD_PROPERTY_TYPE(SideType, (0L), "Pad", App::Prop_None, "Type of sides definition");
|
|
ADD_PROPERTY_TYPE(Type, (0L), "Side1", App::Prop_None, "Pad type for side 1");
|
|
ADD_PROPERTY_TYPE(Type2, (0L), "Side2", App::Prop_None, "Pad type for side 2");
|
|
SideType.setEnums(SideTypesEnums);
|
|
Type.setEnums(TypeEnums);
|
|
Type2.setEnums(TypeEnums);
|
|
ADD_PROPERTY_TYPE(Length, (10.0), "Side1", App::Prop_None, "Pad length");
|
|
ADD_PROPERTY_TYPE(Length2, (10.0), "Side2", App::Prop_None, "Pad length in 2nd direction");
|
|
ADD_PROPERTY_TYPE(UseCustomVector, (false), "Pad", App::Prop_None, "Use custom vector for pad direction");
|
|
ADD_PROPERTY_TYPE(
|
|
Direction,
|
|
(Base::Vector3d(1.0, 1.0, 1.0)),
|
|
"Pad",
|
|
App::Prop_None,
|
|
"Pad direction vector"
|
|
);
|
|
ADD_PROPERTY_TYPE(ReferenceAxis, (nullptr), "Pad", App::Prop_None, "Reference axis of direction");
|
|
ADD_PROPERTY_TYPE(
|
|
AlongSketchNormal,
|
|
(true),
|
|
"Pad",
|
|
App::Prop_None,
|
|
"Measure pad length along the sketch normal direction"
|
|
);
|
|
ADD_PROPERTY_TYPE(UpToFace, (nullptr), "Side1", App::Prop_None, "Face where pad will end");
|
|
ADD_PROPERTY_TYPE(UpToShape, (nullptr), "Side1", App::Prop_None, "Faces or shape(s) where pad will end");
|
|
ADD_PROPERTY_TYPE(UpToFace2, (nullptr), "Side2", App::Prop_None, "Face where pad will end on side2");
|
|
ADD_PROPERTY_TYPE(
|
|
UpToShape2,
|
|
(nullptr),
|
|
"Side2",
|
|
App::Prop_None,
|
|
"Faces or shape(s) where pad will end on side2"
|
|
);
|
|
ADD_PROPERTY_TYPE(Offset, (0.0), "Side1", App::Prop_None, "Offset from face in which pad will end");
|
|
ADD_PROPERTY_TYPE(
|
|
Offset2,
|
|
(0.0),
|
|
"Side2",
|
|
App::Prop_None,
|
|
"Offset from face in which pad will end on side 2"
|
|
);
|
|
Offset.setConstraints(&signedLengthConstraint);
|
|
Offset2.setConstraints(&signedLengthConstraint);
|
|
ADD_PROPERTY_TYPE(TaperAngle, (0.0), "Side1", App::Prop_None, "Taper angle");
|
|
TaperAngle.setConstraints(&floatAngle);
|
|
ADD_PROPERTY_TYPE(TaperAngle2, (0.0), "Side2", App::Prop_None, "Taper angle for 2nd direction");
|
|
TaperAngle2.setConstraints(&floatAngle);
|
|
|
|
// Remove the constraints and keep the type to allow one to accept negative values
|
|
// https://forum.freecad.org/viewtopic.php?f=3&t=52075&p=448410#p447636
|
|
Length.setConstraints(nullptr);
|
|
Length2.setConstraints(nullptr);
|
|
}
|
|
|
|
|
|
App::DocumentObjectExecReturn* Pad::execute()
|
|
{
|
|
return buildExtrusion(ExtrudeOption::MakeFace | ExtrudeOption::MakeFuse);
|
|
}
|