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

📄 halffacet.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// Copyright (c) 1997-2002  Max-Planck-Institute Saarbruecken (Germany).// 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://hachenb@scm.gforge.inria.fr/svn/cgal/branches/Filtered_Nef/Nef_3/include/CGAL/Nef_3/Halffacet.h $// $Id: Halffacet.h 35450 2006-12-06 10:43:20Z hachenb $// //// Author(s)     : Michael Seel        <seel@mpi-sb.mpg.de>//                 Miguel Granados     <granados@mpi-sb.mpg.de>//                 Susan Hert          <hert@mpi-sb.mpg.de>//                 Lutz Kettner        <kettner@mpi-sb.mpg.de>//                 Peter Hachenberger  <hachenberger@mpi-sb.mpg.de>#ifndef CGAL_NEF_HALFFACET_H#define CGAL_NEF_HALFFACET_H#include <string>#include <sstream>#include <CGAL/IO/Verbose_ostream.h>#include <CGAL/Nef_3/SNC_iteration.h>#undef CGAL_NEF_DEBUG#define CGAL_NEF_DEBUG 83#include <CGAL/Nef_2/debug.h>CGAL_BEGIN_NAMESPACEtemplate <typename Refs>class Halffacet_base  {  typedef void* GenPtr;  typedef typename Refs::Mark  Mark;  typedef typename Refs::Plane_3   Plane_3;  typedef typename Refs::Halffacet_handle         Halffacet_handle;  typedef typename Refs::Halffacet_const_handle   Halffacet_const_handle;  typedef typename Refs::Volume_handle            Volume_handle;  typedef typename Refs::Volume_const_handle      Volume_const_handle;  typedef typename Refs::Object_list    Object_list;  typedef typename Refs::Halffacet_cycle_iterator    Halffacet_cycle_iterator;  typedef typename Refs::Halffacet_cycle_const_iterator    Halffacet_cycle_const_iterator;  Plane_3              supporting_plane_;  Mark                 mark_;  Halffacet_handle     twin_;  Volume_handle        volume_;  Object_list          boundary_entry_objects_; // SEdges, SLoops public:  Halffacet_base() : supporting_plane_(), mark_() {}    Halffacet_base(const Plane_3& h, Mark m) :      supporting_plane_(h), mark_(m) {}      ~Halffacet_base() {	CGAL_NEF_TRACEN("  destroying Halffacet_base item "<<&*this);      }      Halffacet_base(const Halffacet_base<Refs>& f)	{ supporting_plane_ = f.supporting_plane_;	  mark_ = f.mark_;	  twin_ = f.twin_;	  CGAL_NEF_TRACEN("VOLUME const");	  volume_ = f.volume_;	  boundary_entry_objects_ = f.boundary_entry_objects_;	}      Halffacet_base<Refs>& operator=(const Halffacet_base<Refs>& f)	{ if (this == &f) return *this;	  supporting_plane_ = f.supporting_plane_;	  mark_ = f.mark_;	  twin_ = f.twin_;	  CGAL_NEF_TRACEN("VOLUME op=");	  volume_ = f.volume_;	  boundary_entry_objects_ = f.boundary_entry_objects_;	  return *this;	}      Mark& mark() { return mark_; }      const Mark& mark() const { return mark_; }      Halffacet_handle& twin() { return twin_; }      Halffacet_const_handle twin() const { return twin_; }      Plane_3& plane() { return supporting_plane_; }      const Plane_3& plane() const { return supporting_plane_; }      Volume_handle& incident_volume() { return volume_; }      Volume_const_handle incident_volume() const { return volume_; }      Object_list& boundary_entry_objects() { return boundary_entry_objects_; }      const Object_list& boundary_entry_objects() const { return boundary_entry_objects_; }      GenPtr& info() { return this->info_; }      const GenPtr& info() const { return this->info_; }      Halffacet_cycle_iterator facet_cycles_begin()      { return boundary_entry_objects_.begin(); }      Halffacet_cycle_iterator facet_cycles_end()      { return boundary_entry_objects_.end(); }      Halffacet_cycle_const_iterator facet_cycles_begin() const      { return boundary_entry_objects_.begin(); }      Halffacet_cycle_const_iterator facet_cycles_end() const      { return boundary_entry_objects_.end(); }      bool is_twin() const { return (&*twin_ < this); }      bool is_valid( bool verb = false, int level = 0) const {      	Verbose_ostream verr(verb);	verr << "begin CGAL::SNC_items<...>::Halffacet_base::is_valid( verb=true, "	  "level = " << level << "):" << std::endl;	bool valid = (twin_ != NULL && twin_ != Halffacet_handle());	valid = valid && (volume_ != NULL && volume_ != Volume_handle());      	valid = valid && (supporting_plane_.a() != 0 || 			  supporting_plane_.b() != 0 ||			  supporting_plane_.c() != 0);      	valid = valid && (!boundary_entry_objects_.empty());	verr << "end of CGAL::SNC_items<...>::Halffacet_base::is_valid(): structure is "	     << ( valid ? "valid." : "NOT VALID.") << std::endl;	return valid;      }}; // Halffacet_baseCGAL_END_NAMESPACE#endif //CGAL_NEF_HALFFACET_H

⌨️ 快捷键说明

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