![]() |
OpenCV
4.6.0
Open Source Computer Vision
|
Class for iterating over all pixels on a raster line segment. More...
#include <opencv2/imgproc.hpp>
Public Member Functions | |
| LineIterator (const Mat &img, Point pt1, Point pt2, int connectivity=8, bool leftToRight=false) | |
| Initializes iterator object for the given line and image. More... | |
| LineIterator (Point pt1, Point pt2, int connectivity=8, bool leftToRight=false) | |
| LineIterator (Size boundingAreaSize, Point pt1, Point pt2, int connectivity=8, bool leftToRight=false) | |
| LineIterator (Rect boundingAreaRect, Point pt1, Point pt2, int connectivity=8, bool leftToRight=false) | |
| void | init (const Mat *img, Rect boundingAreaRect, Point pt1, Point pt2, int connectivity, bool leftToRight) |
| uchar * | operator* () |
| Returns pointer to the current pixel. More... | |
| LineIterator & | operator++ () |
| Moves iterator to the next pixel on the line. More... | |
| LineIterator | operator++ (int) |
| Moves iterator to the next pixel on the line. More... | |
| Point | pos () const |
| Returns coordinates of the current pixel. More... | |
Public Attributes | |
| int | count |
| int | elemSize |
| int | err |
| int | minusDelta |
| int | minusShift |
| int | minusStep |
| Point | p |
| int | plusDelta |
| int | plusShift |
| int | plusStep |
| bool | ptmode |
| uchar * | ptr |
| const uchar * | ptr0 |
| int | step |
Class for iterating over all pixels on a raster line segment.
The class LineIterator is used to get each pixel of a raster line connecting two specified points. It can be treated as a versatile implementation of the Bresenham algorithm where you can stop at each pixel and do some extra processing, for example, grab pixel values along the line or draw a line with an effect (for example, with XOR operation).
The number of pixels along the line is stored in LineIterator::count. The method LineIterator::pos returns the current position in the image:
|
inline |
Initializes iterator object for the given line and image.
The returned iterator can be used to traverse all pixels on a line that connects the given two points. The line will be clipped on the image boundaries.
| img | Underlying image. |
| pt1 | First endpoint of the line. |
| pt2 | The other endpoint of the line. |
| connectivity | Pixel connectivity of the iterator. Valid values are 4 (iterator can move up, down, left and right) and 8 (iterator can also move diagonally). |
| leftToRight | If true, the line is traversed from the leftmost endpoint to the rightmost endpoint. Otherwise, the line is traversed from pt1 to pt2. |
|
inline |
|
inline |
|
inline |
| void cv::LineIterator::init | ( | const Mat * | img, |
| Rect | boundingAreaRect, | ||
| Point | pt1, | ||
| Point | pt2, | ||
| int | connectivity, | ||
| bool | leftToRight | ||
| ) |
| uchar* cv::LineIterator::operator* | ( | ) |
Returns pointer to the current pixel.
| LineIterator& cv::LineIterator::operator++ | ( | ) |
Moves iterator to the next pixel on the line.
This is the prefix version (++it).
| LineIterator cv::LineIterator::operator++ | ( | int | ) |
Moves iterator to the next pixel on the line.
This is the postfix version (it++).
| Point cv::LineIterator::pos | ( | ) | const |
Returns coordinates of the current pixel.
| int cv::LineIterator::count |
| int cv::LineIterator::elemSize |
| int cv::LineIterator::err |
| int cv::LineIterator::minusDelta |
| int cv::LineIterator::minusShift |
| int cv::LineIterator::minusStep |
| Point cv::LineIterator::p |
| int cv::LineIterator::plusDelta |
| int cv::LineIterator::plusShift |
| int cv::LineIterator::plusStep |
| bool cv::LineIterator::ptmode |
| uchar* cv::LineIterator::ptr |
| const uchar* cv::LineIterator::ptr0 |
| int cv::LineIterator::step |
1.8.13