This commit is contained in:
Chenwenxuan
2024-03-06 14:54:30 +08:00
commit edac2715f0
1525 changed files with 809982 additions and 0 deletions

View File

@@ -0,0 +1,85 @@
/****************************************************************************
**
* Draw a common tangent circle of 3 existing circles
* Problem of Appollonius
Copyright (C) 2012 Dongxu Li (dongxuli2011@gmail.com)
Copyright (C) 2011 R. van Twisk (librecad@rvt.dds.nl)
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**********************************************************************/
#ifndef RS_ACTIONDRAWCIRCLETAN3_H
#define RS_ACTIONDRAWCIRCLETAN3_H
#include<vector>
#include "rs_previewactioninterface.h"
struct RS_CircleData;
class RS_AtomicEntity;
/**
* Draw Common tangential circle of 3 given circles, i.e. Appollonius's problem
*
* @author Dongxu Li
*/
class RS_ActionDrawCircleTan3 : public RS_PreviewActionInterface {
Q_OBJECT
public:
/**
* Action States.
*/
enum Status {
SetCircle1, // Setting the First Circle. */
SetCircle2, // Setting the Second Circle. */
SetCircle3, // Setting the Third Circle. */
SetCenter // select the closest tangential Circle. */
};
public:
RS_ActionDrawCircleTan3(RS_EntityContainer& container,
RS_GraphicView& graphicView);
~RS_ActionDrawCircleTan3() override;
void init(int status=0) override;
void trigger() override;
bool getData();
bool preparePreview();
void mouseMoveEvent(QMouseEvent* e) override;
void mouseReleaseEvent(QMouseEvent* e) override;
// void coordinateEvent(RS_CoordinateEvent* e) override;
// void commandEvent(RS_CommandEvent* e) override;
QStringList getAvailableCommands() override;
void finish(bool updateTB=true) override;
void updateMouseButtonHints() override;
void updateMouseCursor() override;
//protected:
private:
std::vector<double> verifyCenter(const RS_Vector& center) const;
std::vector<double> getRadii(RS_AtomicEntity* entity, const RS_Vector& center) const;
RS_Entity* catchCircle(QMouseEvent* e);
struct Points;
std::unique_ptr<Points> pPoints;
//list of entity types supported by current action
const EntityTypeList enTypeList = EntityTypeList {RS2::EntityArc, RS2::EntityCircle, RS2::EntityLine, RS2::EntityPoint};
};
#endif