⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qt_widget_circular_arc_2.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// Copyright (c) 2003-2006  INRIA Sophia-Antipolis (France).// All rights reserved.//// This file is part of CGAL (www.cgal.org); you may redistribute it under// the terms of the Q Public License version 1.0.// See the file LICENSE.QPL distributed with CGAL.//// Licensees holding a valid commercial license may use this file in// accordance with the commercial license agreement provided with the software.//// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.//// $URL: svn+ssh://scm.gforge.inria.fr/svn/cgal/branches/CGAL-3.3-branch/Circular_kernel_2/include/CGAL/IO/Qt_widget_circular_arc_2.h $// $Id: Qt_widget_circular_arc_2.h 28723 2006-02-23 14:42:53Z spion $//// Author(s)     : Monique Teillaud, Sylvain Pion, Radu Ursu// Partially supported by the IST Programme of the EU as a Shared-cost// RTD (FET Open) Project under Contract No  IST-2000-26473 // (ECG - Effective Computational Geometry for Curves and Surfaces) // and a STREP (FET Open) Project under Contract No  IST-006413 // (ACS -- Algorithms for Complex Shapes)#ifndef CGAL_IO_QT_WIDGET_CIRCULAR_ARC_2_H#define CGAL_IO_QT_WIDGET_CIRCULAR_ARC_2_H#include <CGAL/IO/Qt_widget.h>#include <CGAL/Circular_arc_2.h>#include <cmath>namespace CGAL {template < typename CK >CGAL::Qt_widget &operator<<(CGAL::Qt_widget & widget, const CGAL::Circular_arc_2<CK> &arc){    const typename CK::Circle_2 & circ = arc.supporting_circle();    //typename CK::Circle_2 circ = arc.supporting_circle();    const typename CK::Point_2 & center = circ.center();    const typename CK::Circular_arc_point_2 & source = arc.source();    const typename CK::Circular_arc_point_2 & target = arc.target();    double rad = std::sqrt(CGAL::to_double(circ.squared_radius()));    int x_screen   = widget.x_pixel(CGAL::to_double(center.x()));    int y_screen   = widget.y_pixel(CGAL::to_double(center.y()));    int x_screen_b = widget.x_pixel(CGAL::to_double(center.x()) + rad);    int radius     = x_screen_b - x_screen;    double a   = std::atan2( to_double(source.y() - center.y()),		             to_double(source.x() - center.x()));     double a2p = std::atan2( to_double(target.y() - center.y()),		             to_double(target.x() - center.x()));    if (a2p <= a)        a2p += 2 * CGAL_PI;    double alen2 = a2p - a;    double diff = 180/CGAL_PI*16;    widget.get_painter().drawArc(x_screen - radius, 				 y_screen - radius, 				 2 * radius, 2 * radius, 				 (int)(a * diff), 				 (int)(alen2 * diff));    return widget;}} // namespace CGAL#endif // CGAL_IO_QT_WIDGET_CIRCULAR_ARC_2_H

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -