libcrn  3.9.5
A document image processing library
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
CRNImageLab.cpp
Go to the documentation of this file.
1 /* Copyright 2008-2015 INSA Lyon
2  *
3  * This file is part of libcrn.
4  *
5  * libcrn is free software: you can redistribute it and/or modify
6  * it under the terms of the GNU Lesser General Public License as published by
7  * the Free Software Foundation, either version 3 of the License, or
8  * (at your option) any later version.
9  *
10  * libcrn is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public License
16  * along with libcrn. If not, see <http://www.gnu.org/licenses/>.
17  *
18  * file: CRNImageLab.cpp
19  * \author Yann LEYDIER
20  */
21 
22 #include <CRNImage/CRNImageLab.h>
23 #include <CRNImage/CRNImage.h>
24 
25 using namespace crn;
26 
28 {
29  auto res = ImageDoubleGray(img.GetWidth(), img.GetHeight());
30  for (auto tmp : Range(img))
31  res.At(tmp) = img.At(tmp).l;
32  return res;
33 }
34 
36 {
37  auto res = ImageDoubleGray(img.GetWidth(), img.GetHeight());
38  for (auto tmp : Range(img))
39  res.At(tmp) = img.At(tmp).a;
40  return res;
41 }
42 
44 {
45  auto res = ImageDoubleGray(img.GetWidth(), img.GetHeight());
46  for (auto tmp : Range(img))
47  res.At(tmp) = img.At(tmp).b;
48  return res;
49 }
50 
ScalarRange< T > Range(T b, T e)
Creates a range [[b, e[[.
Definition: CRNType.h:257
std::vector< pixel_type >::reference At(size_t x, size_t y) noexcept
Returns a reference to a pixel.
Definition: CRNImage.h:224
size_t GetHeight() const noexcept
Definition: CRNImage.h:74
Image< double > ImageDoubleGray
double Grayscale image class
ImageDoubleGray AChannel(const ImageLab &img)
Definition: CRNImageLab.cpp:35
size_t GetWidth() const noexcept
Definition: CRNImage.h:72
ImageDoubleGray LChannel(const ImageLab &img)
Definition: CRNImageLab.cpp:27
ImageDoubleGray BChannel(const ImageLab &img)
Definition: CRNImageLab.cpp:43