bresenham.h
Go to the documentation of this file.
00001 /*
00002  * Software License Agreement (BSD License)
00003  *
00004  *  Copyright (c) 2018, Locus Robotics
00005  *  All rights reserved.
00006  *
00007  *  Redistribution and use in source and binary forms, with or without
00008  *  modification, are permitted provided that the following conditions
00009  *  are met:
00010  *
00011  *   * Redistributions of source code must retain the above copyright
00012  *     notice, this list of conditions and the following disclaimer.
00013  *   * Redistributions in binary form must reproduce the above
00014  *     copyright notice, this list of conditions and the following
00015  *     disclaimer in the documentation and/or other materials provided
00016  *     with the distribution.
00017  *   * Neither the name of the copyright holder nor the names of its
00018  *     contributors may be used to endorse or promote products derived
00019  *     from this software without specific prior written permission.
00020  *
00021  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00022  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00023  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00024  *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00025  *  COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00026  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00027  *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00028  *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00029  *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00030  *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00031  *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00032  *  POSSIBILITY OF SUCH DAMAGE.
00033  */
00034 
00035 #ifndef NAV_GRID_ITERATORS_LINE_BRESENHAM_H
00036 #define NAV_GRID_ITERATORS_LINE_BRESENHAM_H
00037 
00038 #include <nav_grid_iterators/line/abstract_line_iterator.h>
00039 
00040 namespace nav_grid_iterators
00041 {
00046 class Bresenham : public AbstractLineIterator
00047 {
00048 public:
00057   Bresenham(int x0, int y0, int x1, int y1, bool include_last_index = true);
00058 
00062   bool operator==(const Bresenham& other)
00063   {
00064     return x0_ == other.x0_ && y0_ == other.y0_ && x1_ == other.x1_ && y1_ == other.y1_ && index_ == other.index_;
00065   }
00066 
00070   bool operator!=(const Bresenham& other) { return !(*this == other); }
00071 
00076   Bresenham begin() const;
00077 
00082   Bresenham end() const;
00083 
00084   nav_grid::SignedIndex getFinalIndex() const override;
00085   void increment() override;
00086 
00091   Bresenham& operator++()
00092   {
00093     increment();
00094     return *this;
00095   }
00096 
00097   using self_type = Bresenham;
00098   using value_type = nav_grid::SignedIndex;
00099   using reference = nav_grid::SignedIndex&;
00100   using pointer = nav_grid::SignedIndex*;
00101   using iterator_category = std::input_iterator_tag;
00102   using difference_type = int;
00103 
00104 protected:
00121   Bresenham(const nav_grid::SignedIndex& index,
00122        int x0, int y0, int x1, int y1, bool include_last_index,
00123        int error_inc_x, int loop_inc_x, int error_inc_y, int loop_inc_y,
00124        int denominator, int numerator, int numerator_inc);
00125 
00126 
00127   int x0_, y0_, x1_, y1_;
00128   bool include_last_index_;
00129   int error_inc_x_, loop_inc_x_, error_inc_y_, loop_inc_y_;
00130   int denominator_, numerator_, numerator_inc_;
00131 };
00132 
00133 
00134 }  // namespace nav_grid_iterators
00135 
00136 #endif  // NAV_GRID_ITERATORS_LINE_BRESENHAM_H


nav_grid_iterators
Author(s):
autogenerated on Wed Jun 26 2019 20:09:45