~librecad-dev/librecad/librecad

« back to all changes in this revision

Viewing changes to librecad/src/actions/rs_actiondrawpolyline.h

  • Committer: Scott Howard
  • Date: 2014-02-21 19:07:55 UTC
  • Revision ID: showard@debian.org-20140221190755-csjax9wb146hgdq4
first commit

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/****************************************************************************
 
2
**
 
3
** This file is part of the LibreCAD project, a 2D CAD program
 
4
**
 
5
** Copyright (C) 2010 R. van Twisk (librecad@rvt.dds.nl)
 
6
** Copyright (C) 2001-2003 RibbonSoft. All rights reserved.
 
7
**
 
8
**
 
9
** This file may be distributed and/or modified under the terms of the
 
10
** GNU General Public License version 2 as published by the Free Software 
 
11
** Foundation and appearing in the file gpl-2.0.txt included in the
 
12
** packaging of this file.
 
13
**
 
14
** This program is distributed in the hope that it will be useful,
 
15
** but WITHOUT ANY WARRANTY; without even the implied warranty of
 
16
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
17
** GNU General Public License for more details.
 
18
** 
 
19
** You should have received a copy of the GNU General Public License
 
20
** along with this program; if not, write to the Free Software
 
21
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 
22
**
 
23
** This copyright notice MUST APPEAR in all copies of the script!  
 
24
**
 
25
**********************************************************************/
 
26
 
 
27
#ifndef RS_ACTIONDRAWPOLYLINE_H
 
28
#define RS_ACTIONDRAWPOLYLINE_H
 
29
 
 
30
#include "rs_previewactioninterface.h"
 
31
#include "rs_polyline.h"
 
32
 
 
33
 
 
34
/**
 
35
 * This action class can handle user events to draw 
 
36
 * simple lines with the start- and endpoint given.
 
37
 *
 
38
 * @author Andrew Mustun
 
39
*/
 
40
class RS_ActionDrawPolyline : public RS_PreviewActionInterface {
 
41
        Q_OBJECT
 
42
public:
 
43
    /**
 
44
     * Action States.
 
45
     */
 
46
    enum Status {
 
47
        SetStartpoint,   /**< Setting the startpoint.  */
 
48
        SetNextPoint      /**< Setting the endpoint. */
 
49
    };
 
50
 
 
51
    enum Mode {
 
52
        Line,
 
53
        Tangential,
 
54
        TanRad,
 
55
//      TanAng,
 
56
//      TanRadAng,
 
57
        Ang,
 
58
//      RadAngEndp,
 
59
//      RadAngCenp
 
60
    };
 
61
 
 
62
public:
 
63
    RS_ActionDrawPolyline(RS_EntityContainer& container,
 
64
                      RS_GraphicView& graphicView);
 
65
    virtual ~RS_ActionDrawPolyline();
 
66
 
 
67
        virtual RS2::ActionType rtti() {
 
68
                return RS2::ActionDrawPolyline;
 
69
        }
 
70
 
 
71
        static QAction* createGUIAction(RS2::ActionType /*type*/, QObject* /*parent*/);
 
72
        
 
73
    void reset();
 
74
 
 
75
    virtual void init(int status=0);
 
76
    virtual void trigger();
 
77
        
 
78
    virtual void mouseMoveEvent(QMouseEvent* e);
 
79
    virtual void mouseReleaseEvent(QMouseEvent* e);
 
80
        
 
81
        virtual void coordinateEvent(RS_CoordinateEvent* e);
 
82
    virtual void commandEvent(RS_CommandEvent* e);
 
83
        virtual QStringList getAvailableCommands();
 
84
        
 
85
        virtual void showOptions();
 
86
        virtual void hideOptions();
 
87
        
 
88
    virtual void updateMouseButtonHints();
 
89
    virtual void updateMouseCursor();
 
90
//    virtual void updateToolBar();
 
91
 
 
92
        void close();
 
93
        void undo();
 
94
 
 
95
        void setMode(int m) {
 
96
                Mode=m;
 
97
        }
 
98
 
 
99
        int getMode() {
 
100
                return Mode;
 
101
        }
 
102
 
 
103
        void setRadius(double r) {
 
104
                Radius=r;
 
105
        }
 
106
 
 
107
        double getRadius() {
 
108
                return Radius;
 
109
        }
 
110
 
 
111
        void setAngle(double a) {
 
112
                Angle=a;
 
113
        }
 
114
 
 
115
        double getAngle() {
 
116
                return Angle;
 
117
        }
 
118
 
 
119
        void setReversed( bool c) {
 
120
                if (c)
 
121
                        Reversed = -1;
 
122
                else
 
123
                        Reversed = 1;
 
124
        }
 
125
 
 
126
        bool isReversed() {
 
127
                if(Reversed==-1)
 
128
                  return true;
 
129
                else
 
130
                  return false;
 
131
        }
 
132
 
 
133
        double solveBulge(RS_Vector mouse);
 
134
 
 
135
protected:
 
136
    double Radius;
 
137
    double Angle;
 
138
    int Mode;
 
139
    int Reversed;
 
140
    bool calculatedSegment;
 
141
 
 
142
    /**
 
143
     * Line data defined so far.
 
144
     */
 
145
    RS_PolylineData data;
 
146
    RS_ArcData arc_data;        
 
147
    /**
 
148
     * Polyline entity we're working on.
 
149
     */
 
150
    RS_Polyline* polyline;
 
151
        
 
152
    /**
 
153
     * last point.
 
154
     */
 
155
    RS_Vector point;
 
156
    RS_Vector calculatedEndpoint;
 
157
        /**
 
158
         * Start point of the series of lines. Used for close function.
 
159
         */
 
160
        RS_Vector start;
 
161
 
 
162
        /**
 
163
         * Point history (for undo)
 
164
         */
 
165
        QList<RS_Vector> history;
 
166
        
 
167
        /**
 
168
         * Bulge history (for undo)
 
169
         */
 
170
        QList<double> bHistory;
 
171
};
 
172
 
 
173
#endif