File size: 4,278 Bytes
985c397
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
// SPDX-License-Identifier: LGPL-2.1-or-later

/***************************************************************************
 *   Copyright (c) 2017 Shai Seger <shaise at gmail>                       *
 *                                                                         *
 *   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                                *
 *                                                                         *
 ***************************************************************************/

#ifndef PATHSIMULATOR_CAMSimulatorGui_H
#define PATHSIMULATOR_CAMSimulatorGui_H

#ifdef _MSC_VER
# pragma warning(disable : 4251)
#endif

#include <Mod/Part/App/TopoShape.h>
#include <QWindow>
#include <QOpenGLExtraFunctions>
#include <QPainter>
#include <QExposeEvent>
#include <QResizeEvent>
#include <QMouseEvent>
#include <QOpenGLContext>

namespace MillSim
{
// use short declaration as using 'include' causes a header loop
class MillSimulation;
struct Vertex;
}  // namespace MillSim

namespace CAMSimulator
{

struct SimStock
{
public:
    SimStock(float px, float py, float pz, float lx, float ly, float lz, float res);
    ~SimStock();

public:
    float mPx, mPy, mPz;  // stock zero position
    float mLx, mLy, mLz;  // stock dimensions
};

class DlgCAMSimulator: public QWindow, public QOpenGLExtraFunctions
{
    Q_OBJECT
public:
    explicit DlgCAMSimulator(QWindow* parent = nullptr);
    ~DlgCAMSimulator() override;

    virtual void render(QPainter* painter);
    virtual void render();
    virtual void initialize();

    void setAnimating(bool animating);
    static DlgCAMSimulator* GetInstance();
    void SetStockShape(const Part::TopoShape& tshape, float resolution);
    void SetBaseShape(const Part::TopoShape& tshape, float resolution);

public:  // slots:
    void renderLater();
    void renderNow();
    void startSimulation(const Part::TopoShape& stock, float quality);
    void resetSimulation();
    void addGcodeCommand(const char* cmd);
    void addTool(
        const std::vector<float>& toolProfilePoints,
        int toolNumber,
        float diameter,
        float resolution
    );

protected:
    bool event(QEvent* event) override;
    void checkInitialization();
    void doGlCleanup();
    void exposeEvent(QExposeEvent* event) override;
    void mouseMoveEvent(QMouseEvent* ev) override;
    void mousePressEvent(QMouseEvent* ev) override;
    void mouseReleaseEvent(QMouseEvent* ev) override;
    void wheelEvent(QWheelEvent* ev) override;
    void hideEvent(QHideEvent* ev) override;
    void resizeEvent(QResizeEvent* event) override;
    void GetMeshData(
        const Part::TopoShape& tshape,
        float resolution,
        std::vector<MillSim::Vertex>& verts,
        std::vector<GLushort>& indices
    );

private:
    bool mAnimating = false;
    bool mNeedsInitialize = false;

    QOpenGLContext* mContext = nullptr;
    QOpenGLContext* mLastContext = nullptr;
    MillSim::MillSimulation* mMillSimulator = nullptr;
    static DlgCAMSimulator* mInstance;
    float mQuality = 10;
};


}  // namespace CAMSimulator


#endif  // PATHSIMULATOR_PathSim_H