| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
| 5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
| 6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| 11 #ifndef WEBRTC_MODULES_DESKTOP_CAPTURE_RGBA_COLOR_H_ | 11 #ifndef WEBRTC_MODULES_DESKTOP_CAPTURE_RGBA_COLOR_H_ |
| 12 #define WEBRTC_MODULES_DESKTOP_CAPTURE_RGBA_COLOR_H_ | 12 #define WEBRTC_MODULES_DESKTOP_CAPTURE_RGBA_COLOR_H_ |
| 13 | 13 |
| 14 #include <stdint.h> | 14 #include <stdint.h> |
| 15 | 15 |
| 16 #include "webrtc/modules/desktop_capture/desktop_frame.h" | |
| 17 | |
| 18 namespace webrtc { | 16 namespace webrtc { |
| 19 | 17 |
| 20 // A four-byte structure to store a color in BGRA format. This structure also | 18 // A four-byte structure to store a color in BGRA format. This structure also |
| 21 // provides functions to be created from uint8_t array, say, | 19 // provides functions to be created from uint8_t array, say, |
| 22 // DesktopFrame::data(). It always uses BGRA order for internal storage to match | 20 // DesktopFrame::data(). It always uses BGRA order for internal storage to match |
| 23 // DesktopFrame::data(). | 21 // DesktopFrame::data(). |
| 24 // | 22 // |
| 25 // This struct is for testing purpose only, and should not be used in production | 23 // This struct is for testing purpose only, and should not be used in production |
| 26 // logic. | 24 // logic. |
| 27 struct RgbaColor final { | 25 struct RgbaColor final { |
| 28 // Creates a color with BGRA channels. | 26 // Creates a color with BGRA channels. |
| 29 RgbaColor(uint8_t blue, uint8_t green, uint8_t red, uint8_t alpha); | 27 RgbaColor(uint8_t blue, uint8_t green, uint8_t red, uint8_t alpha); |
| 30 | 28 |
| 31 // Creates a color with BGR channels, and set alpha channel to 255 (opaque). | 29 // Creates a color with BGR channels, and set alpha channel to 255 (opaque). |
| 32 RgbaColor(uint8_t blue, uint8_t green, uint8_t red); | 30 RgbaColor(uint8_t blue, uint8_t green, uint8_t red); |
| 33 | 31 |
| 34 // Creates a color from four-byte in BGRA order, i.e. DesktopFrame::data(). | 32 // Creates a color from four-byte in BGRA order, i.e. DesktopFrame::data(). |
| 35 explicit RgbaColor(const uint8_t* bgra); | 33 explicit RgbaColor(const uint8_t* bgra); |
| 36 | 34 |
| 37 // Creates a color from BGRA channels in a uint format. Consumers should make | 35 // Creates a color from BGRA channels in a uint format. Consumers should make |
| 38 // sure the memory order of the uint32_t is always BGRA from left to right, no | 36 // sure the memory order of the uint32_t is always BGRA from left to right, no |
| 39 // matter the system endian. This function creates an equivalent RgbaColor | 37 // matter the system endian. This function creates an equivalent RgbaColor |
| 40 // instance from the ToUInt32() result of another RgbaColor instance. | 38 // instance from the ToUInt32() result of another RgbaColor instance. |
| 41 explicit RgbaColor(uint32_t bgra); | 39 explicit RgbaColor(uint32_t bgra); |
| 42 | 40 |
| 41 // Converts an int to uint32_t, and creates a RGBA instance. This constructor |
| 42 // helps users to write RgbaColor(0) without ambiguous conversion error. |
| 43 explicit RgbaColor(int bgra); |
| 44 |
| 43 // Returns true if |this| and |right| is the same color. | 45 // Returns true if |this| and |right| is the same color. |
| 44 bool operator==(const RgbaColor& right) const; | 46 bool operator==(const RgbaColor& right) const; |
| 45 | 47 |
| 46 // Returns true if |this| and |right| are different colors. | 48 // Returns true if |this| and |right| are different colors. |
| 47 bool operator!=(const RgbaColor& right) const; | 49 bool operator!=(const RgbaColor& right) const; |
| 48 | 50 |
| 49 uint32_t ToUInt32() const; | 51 uint32_t ToUInt32() const; |
| 50 | 52 |
| 51 uint8_t blue; | 53 uint8_t blue; |
| 52 uint8_t green; | 54 uint8_t green; |
| 53 uint8_t red; | 55 uint8_t red; |
| 54 uint8_t alpha; | 56 uint8_t alpha; |
| 55 }; | 57 }; |
| 56 static_assert( | |
| 57 DesktopFrame::kBytesPerPixel == sizeof(RgbaColor), | |
| 58 "A pixel in DesktopFrame should be safe to be represented by a RgbaColor"); | |
| 59 | 58 |
| 60 } // namespace webrtc | 59 } // namespace webrtc |
| 61 | 60 |
| 62 #endif // WEBRTC_MODULES_DESKTOP_CAPTURE_RGBA_COLOR_H_ | 61 #endif // WEBRTC_MODULES_DESKTOP_CAPTURE_RGBA_COLOR_H_ |
| OLD | NEW |