Anti-Grain Geometry - AGG (libagg)
2.5
|
00001 //---------------------------------------------------------------------------- 00002 // Anti-Grain Geometry (AGG) - Version 2.5 00003 // A high quality rendering engine for C++ 00004 // Copyright (C) 2002-2006 Maxim Shemanarev 00005 // Contact: mcseem@antigrain.com 00006 // mcseemagg@yahoo.com 00007 // http://antigrain.com 00008 // 00009 // AGG is free software; you can redistribute it and/or 00010 // modify it under the terms of the GNU General Public License 00011 // as published by the Free Software Foundation; either version 2 00012 // of the License, or (at your option) any later version. 00013 // 00014 // AGG is distributed in the hope that it will be useful, 00015 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00017 // GNU General Public License for more details. 00018 // 00019 // You should have received a copy of the GNU General Public License 00020 // along with AGG; if not, write to the Free Software 00021 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, 00022 // MA 02110-1301, USA. 00023 //---------------------------------------------------------------------------- 00024 00025 #ifndef AGG_BITSET_ITERATOR_INCLUDED 00026 #define AGG_BITSET_ITERATOR_INCLUDED 00027 00028 #include "agg_basics.h" 00029 00030 namespace agg 00031 { 00032 00033 class bitset_iterator 00034 { 00035 public: 00036 bitset_iterator(const int8u* bits, unsigned offset = 0) : 00037 m_bits(bits + (offset >> 3)), 00038 m_mask(0x80 >> (offset & 7)) 00039 {} 00040 00041 void operator ++ () 00042 { 00043 m_mask >>= 1; 00044 if(m_mask == 0) 00045 { 00046 ++m_bits; 00047 m_mask = 0x80; 00048 } 00049 } 00050 00051 unsigned bit() const 00052 { 00053 return (*m_bits) & m_mask; 00054 } 00055 00056 private: 00057 const int8u* m_bits; 00058 int8u m_mask; 00059 }; 00060 00061 } 00062 00063 #endif