Zivid C++ API  1.8.1+6967bc1b-1
Defining the Future of 3D Machine Vision
Image.h
Go to the documentation of this file.
1 
2 /*******************************************************************************
3  * This file is part of the Zivid 3D Camera API
4  *
5  * Copyright 2015-2020 (C) Zivid AS
6  * All rights reserved.
7  *
8  * Zivid Software License, v1.0
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions are met:
12  *
13  * 1. Redistributions of source code must retain the above copyright notice,
14  * this list of conditions and the following disclaimer.
15  *
16  * 2. Redistributions in binary form must reproduce the above copyright notice,
17  * this list of conditions and the following disclaimer in the documentation
18  * and/or other materials provided with the distribution.
19  *
20  * 3. Neither the name of Zivid AS nor the names of its contributors may be used
21  * to endorse or promote products derived from this software without specific
22  * prior written permission.
23  *
24  * 4. This software, with or without modification, must not be used with any
25  * other 3D camera than from Zivid AS.
26  *
27  * 5. Any software provided in binary form under this license must not be
28  * reverse engineered, decompiled, modified and/or disassembled.
29  *
30  * THIS SOFTWARE IS PROVIDED BY ZIVID AS "AS IS" AND ANY EXPRESS OR IMPLIED
31  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
32  * MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
33  * DISCLAIMED. IN NO EVENT SHALL ZIVID AS OR CONTRIBUTORS BE LIABLE FOR ANY
34  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
35  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
36  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
37  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
38  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
39  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
40  *
41  * Contact: Zivid Support <support@zivid.com>
42  * Info: http://www.zivid.com
43  ******************************************************************************/
44 
45 #pragma once
46 
47 #include "Zivid/APIExport.h"
48 
49 #include <memory>
50 #include <string>
51 #include <type_traits>
52 
53 namespace Zivid
54 {
55  struct RGBA8
56  {
57  uint8_t r, g, b, a;
58  };
59  static_assert(sizeof(RGBA8) == 4, "RGBA8 must be packed");
60 
61  template<class PixelFormat>
62  class ImageImpl;
63 
66  template<class PixelFormat>
67  class Image
68  {
69  public:
70  static_assert(std::is_same<PixelFormat, Zivid::RGBA8>::value, "PixelFormat must be Zivid::RGBA8.");
71 
73  ZIVID_API_EXPORT_TEMPLATE_H size_t width() const;
74 
76  ZIVID_API_EXPORT_TEMPLATE_H size_t height() const;
77 
79  ZIVID_API_EXPORT_TEMPLATE_H size_t size() const;
80 
83  ZIVID_API_EXPORT_TEMPLATE_H const PixelFormat *dataPtr() const;
84 
87  const PixelFormat &operator()(size_t idx) const
88  {
89  return *(dataPtr() + idx);
90  }
91 
95  const PixelFormat &operator()(size_t i, size_t j) const
96  {
97  return operator()(width() * i + j);
98  }
99 
102  ZIVID_API_EXPORT_TEMPLATE_H void save(const std::string &fileName) const;
103 
105  ZIVID_API_EXPORT_TEMPLATE_H std::string toString() const;
106 
107 #ifndef NO_DOC
108  explicit Image(ImageImpl<PixelFormat> &&imageImpl)
109  : m_impl(std::make_shared<ImageImpl<PixelFormat>>(std::move(imageImpl)))
110  {}
111 #endif
112 
113  private:
114  std::shared_ptr<ImageImpl<PixelFormat>> m_impl;
115  };
116 } // namespace Zivid
Zivid::Image::height
ZIVID_API_EXPORT_TEMPLATE_H size_t height() const
Return height (number of rows) of image
Zivid::RGBA8::r
uint8_t r
Definition: Image.h:136
Zivid::Image::operator()
const PixelFormat & operator()(size_t idx) const
Obtain a constant reference to a pixel given by a 1D linear index.
Definition: Image.h:126
Zivid::ImageImpl
Definition: Image.h:101
Zivid::RGBA8::b
uint8_t b
Definition: Image.h:136
Zivid::RGBA8::g
uint8_t g
Definition: Image.h:136
APIExport.h
Zivid::Image::save
ZIVID_API_EXPORT_TEMPLATE_H void save(const std::string &fileName) const
Save the image to a file. The supported file type is PNG with extension .png. This method will throw ...
ZIVID_API_EXPORT_TEMPLATE_H
#define ZIVID_API_EXPORT_TEMPLATE_H
Definition: APIExport.h:76
Zivid::Image::toString
ZIVID_API_EXPORT_TEMPLATE_H std::string toString() const
Get image information as string
Zivid::Image::size
ZIVID_API_EXPORT_TEMPLATE_H size_t size() const
Return number of pixels in the image
Zivid::RGBA8::a
uint8_t a
Definition: Image.h:136
Zivid
The main Zivid namespace. All Zivid code is found here
Definition: Application.h:52
Zivid::Image::dataPtr
const ZIVID_API_EXPORT_TEMPLATE_H PixelFormat * dataPtr() const
Obtain a pointer to the first pixel in the image. The pointer is valid for the lifetime of this objec...
Zivid::Image::width
ZIVID_API_EXPORT_TEMPLATE_H size_t width() const
Return width (number of columns) of image
Zivid::Image
A 2-dimensional image stored on the host. The format of each pixel is given by template parameter Pix...
Definition: Image.h:106