FreeCAD

Форк
0
/
PrismExtension.cpp 
78 строк · 3.3 Кб
1
/***************************************************************************
2
 *   Copyright (c) 2021 Werner Mayer <wmayer[at]users.sourceforge.net>     *
3
 *                                                                         *
4
 *   This file is part of the FreeCAD CAx development system.              *
5
 *                                                                         *
6
 *   This library is free software; you can redistribute it and/or         *
7
 *   modify it under the terms of the GNU Library General Public           *
8
 *   License as published by the Free Software Foundation; either          *
9
 *   version 2 of the License, or (at your option) any later version.      *
10
 *                                                                         *
11
 *   This library  is distributed in the hope that it will be useful,      *
12
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
13
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
14
 *   GNU Library General Public License for more details.                  *
15
 *                                                                         *
16
 *   You should have received a copy of the GNU Library General Public     *
17
 *   License along with this library; see the file COPYING.LIB. If not,    *
18
 *   write to the Free Software Foundation, Inc., 59 Temple Place,         *
19
 *   Suite 330, Boston, MA  02111-1307, USA                                *
20
 *                                                                         *
21
 ***************************************************************************/
22

23
#include "PreCompiled.h"
24
#ifndef _PreComp_
25
# include <BRepPrimAPI_MakePrism.hxx>
26
#endif
27

28
#include <Base/Tools.h>
29

30
#include "PrismExtension.h"
31

32

33
using namespace Part;
34

35
EXTENSION_PROPERTY_SOURCE(Part::PrismExtension, App::DocumentObjectExtension)
36

37
PrismExtension::PrismExtension()
38
{
39
    EXTENSION_ADD_PROPERTY_TYPE(FirstAngle, (0.0f), "Prism", App::Prop_None, "Angle in first direction");
40
    EXTENSION_ADD_PROPERTY_TYPE(SecondAngle, (0.0f), "Prism", App::Prop_None, "Angle in second direction");
41

42
    static const App::PropertyQuantityConstraint::Constraints angleConstraint = { -89.99999, 89.99999, 1.0 };
43
    FirstAngle.setConstraints(&angleConstraint);
44
    SecondAngle.setConstraints(&angleConstraint);
45

46
    initExtensionType(PrismExtension::getExtensionClassTypeId());
47
}
48

49
PrismExtension::~PrismExtension() = default;
50

51
short int PrismExtension::extensionMustExecute()
52
{
53
    if (FirstAngle.isTouched())
54
        return 1;
55
    if (SecondAngle.isTouched())
56
        return 1;
57
    return DocumentObjectExtension::extensionMustExecute();
58
}
59

60
App::DocumentObjectExecReturn *PrismExtension::extensionExecute()
61
{
62
    return App::DocumentObjectExtension::extensionExecute();
63
}
64

65
void PrismExtension::extensionOnChanged(const App::Property* prop)
66
{
67
    App::DocumentObjectExtension::extensionOnChanged(prop);
68
}
69

70
TopoDS_Shape PrismExtension::makePrism(double height, const TopoDS_Face& face) const
71
{
72
    // the direction vector for the prism is the height for z and the given angle
73
    BRepPrimAPI_MakePrism mkPrism(face,
74
        gp_Vec(height * tan(Base::toRadians<double>(FirstAngle.getValue())),
75
               height * tan(Base::toRadians<double>(SecondAngle.getValue())),
76
               height));
77
    return mkPrism.Shape();
78
}
79

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.