HikoGUI
A low latency retained GUI
Loading...
Searching...
No Matches
srgb_abgr8_pack.hpp
Go to the documentation of this file.
1// Copyright Take Vos 2020-2022.
2// Distributed under the Boost Software License, Version 1.0.
3// (See accompanying file LICENSE_1_0.txt or copy at https://www.boost.org/LICENSE_1_0.txt)
4
9#pragma once
10
11#include "sfloat_rgba16.hpp"
12#include "../color/module.hpp"
13#include "../macros.hpp"
14#include <algorithm>
15
16namespace hi::inline v1 {
17
23 uint32_t v = {};
24
25public:
26 constexpr srgb_abgr8_pack() = default;
27 constexpr srgb_abgr8_pack(srgb_abgr8_pack const &rhs) noexcept = default;
28 constexpr srgb_abgr8_pack(srgb_abgr8_pack &&rhs) noexcept = default;
29 constexpr srgb_abgr8_pack &operator=(srgb_abgr8_pack const &rhs) noexcept = default;
30 constexpr srgb_abgr8_pack &operator=(srgb_abgr8_pack &&rhs) noexcept = default;
31
32 constexpr srgb_abgr8_pack(uint32_t const &rhs) noexcept : v(rhs) {}
33 constexpr srgb_abgr8_pack &operator=(uint32_t const &rhs) noexcept
34 {
35 v = rhs;
36 return *this;
37 }
38 constexpr operator uint32_t() noexcept
39 {
40 return v;
41 }
42
43 //constexpr srgb_abgr8_pack(sfloat_rgba16 const &rhs) noexcept
44 //{
45 // hilet &rhs_v = rhs.get();
46 //
47 // hilet r = sRGB_linear16_to_gamma8(rhs_v[0].get());
48 // hilet g = sRGB_linear16_to_gamma8(rhs_v[1].get());
49 // hilet b = sRGB_linear16_to_gamma8(rhs_v[2].get());
50 // hilet a = static_cast<uint8_t>(std::clamp(rhs_v[3] * 255.0f, 0.0f, 255.0f));
51 // v = (static_cast<uint32_t>(a) << 24) | (static_cast<uint32_t>(b) << 16) | (static_cast<uint32_t>(g) << 8) |
52 // static_cast<uint32_t>(r);
53 //}
54
55 //constexpr srgb_abgr8_pack &operator=(sfloat_rgba16 const &rhs) noexcept
56 //{
57 // hilet &rhs_v = rhs.get();
58 //
59 // hilet r = sRGB_linear16_to_gamma8(rhs_v[0]);
60 // hilet g = sRGB_linear16_to_gamma8(rhs_v[1]);
61 // hilet b = sRGB_linear16_to_gamma8(rhs_v[2]);
62 // hilet a = static_cast<uint8_t>(std::clamp(rhs_v[3] * 255.0f, 0.0f, 255.0f));
63 // v = (static_cast<uint32_t>(a) << 24) | (static_cast<uint32_t>(b) << 16) | (static_cast<uint32_t>(g) << 8) |
64 // static_cast<uint32_t>(r);
65 // return *this;
66 //}
67
68 [[nodiscard]] constexpr friend bool operator==(srgb_abgr8_pack const &lhs, srgb_abgr8_pack const &rhs) noexcept = default;
69
70 [[nodiscard]] constexpr friend srgb_abgr8_pack makeTransparent(srgb_abgr8_pack const &rhs) noexcept
71 {
72 return {rhs.v & 0x00ffffff};
73 }
74};
75
76//inline void fill(pixmap<srgb_abgr8_pack> &dst, pixmap<sfloat_rgba16> const &src) noexcept
77//{
78// hi_assert(dst.width >= src.width);
79// hi_assert(dst.height >= src.height);
80//
81// for (auto rowNr = 0; rowNr < src.height; rowNr++) {
82// hilet srcRow = src.at(rowNr);
83// auto dstRow = dst.at(rowNr);
84// for (auto columnNr = 0; columnNr < src.width; columnNr++) {
85// dstRow[columnNr] = srcRow[columnNr];
86// }
87// }
88//}
89
90} // namespace hi::inline v1
Defines the sfloat_rgba16.
DOXYGEN BUG.
Definition algorithm.hpp:16
constexpr Out narrow_cast(In const &rhs) noexcept
Cast numeric values without loss of precision.
Definition cast.hpp:377
4 x uint8_t pixel packed format with sRGB transfer function.
Definition srgb_abgr8_pack.hpp:22