Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add DragValues for RGB(A) in the color picker #2734

Merged
merged 29 commits into from
Jan 7, 2024
Merged
Show file tree
Hide file tree
Changes from 28 commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
76e98a3
add RGBA values input fields for color_picker
IVAN-MK7 Feb 12, 2023
c863ae3
Merge branch 'emilk:master' into color-picker-rgba-input
IVAN-MK7 Feb 12, 2023
42ed529
cranky suggestions applied
IVAN-MK7 Feb 13, 2023
2cb5b20
Merge branch 'color-picker-rgba-input' of https://github.com/IVAN-MK7…
IVAN-MK7 Feb 13, 2023
be65b18
add color_picker RGBA DragValue prefix
IVAN-MK7 Mar 2, 2023
9d3bbd3
srgba_edit_ui using Color32
IVAN-MK7 Mar 2, 2023
f59c004
typos fix
IVAN-MK7 Mar 29, 2023
ba78e13
srgba_edit_ui use rgba unmultiplied u8 array
IVAN-MK7 Mar 30, 2023
0dece52
Update crates/egui/src/widgets/color_picker.rs
IVAN-MK7 Jun 7, 2023
5c83b18
srgba_edit_ui true on change of ref rbga array
IVAN-MK7 Jun 7, 2023
278dfe1
spell fix
IVAN-MK7 Jun 7, 2023
326e034
add rgba_edit_ui for f32
IVAN-MK7 Jun 8, 2023
c6e4546
merged with up to date origin master
IVAN-MK7 Oct 7, 2023
e3e23f5
removed duplicated functions
IVAN-MK7 Oct 7, 2023
9f399a4
Merge branch 'emilk-master' into color-picker-rgba-input
IVAN-MK7 Oct 7, 2023
ef89897
color_picker rearrange and input type add
IVAN-MK7 Oct 8, 2023
d3e1da8
color_text_ui now displays unmultiplied values
IVAN-MK7 Oct 8, 2023
e2df3de
rearrange buttons layout, remove rgba values label
IVAN-MK7 Nov 10, 2023
facaf95
remove colon from rgba dragvalue prefix
IVAN-MK7 Nov 10, 2023
0e4418e
Add is_additive_alpha helper
emilk Jan 7, 2024
ce29b3e
Merge branch 'master' into color-picker-rgba-input
emilk Jan 7, 2024
b278fa1
Use proper docstrings
emilk Jan 7, 2024
847d2f0
Add function for color picker type button
emilk Jan 7, 2024
61b951b
Clean up drag-values
emilk Jan 7, 2024
b581848
Code cleanup
emilk Jan 7, 2024
c0f143f
Only copy three decimals
emilk Jan 7, 2024
80c7317
Ui for picking global color input type
emilk Jan 7, 2024
e6cff8d
Better names
emilk Jan 7, 2024
b62d766
Move U8/F button
emilk Jan 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 22 additions & 10 deletions crates/ecolor/src/hsva.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,23 +28,23 @@ impl Hsva {

/// From `sRGBA` with premultiplied alpha
#[inline]
pub fn from_srgba_premultiplied(srgba: [u8; 4]) -> Self {
pub fn from_srgba_premultiplied([r, g, b, a]: [u8; 4]) -> Self {
Self::from_rgba_premultiplied(
linear_f32_from_gamma_u8(srgba[0]),
linear_f32_from_gamma_u8(srgba[1]),
linear_f32_from_gamma_u8(srgba[2]),
linear_f32_from_linear_u8(srgba[3]),
linear_f32_from_gamma_u8(r),
linear_f32_from_gamma_u8(g),
linear_f32_from_gamma_u8(b),
linear_f32_from_linear_u8(a),
)
}

/// From `sRGBA` without premultiplied alpha
#[inline]
pub fn from_srgba_unmultiplied(srgba: [u8; 4]) -> Self {
pub fn from_srgba_unmultiplied([r, g, b, a]: [u8; 4]) -> Self {
Self::from_rgba_unmultiplied(
linear_f32_from_gamma_u8(srgba[0]),
linear_f32_from_gamma_u8(srgba[1]),
linear_f32_from_gamma_u8(srgba[2]),
linear_f32_from_linear_u8(srgba[3]),
linear_f32_from_gamma_u8(r),
linear_f32_from_gamma_u8(g),
linear_f32_from_gamma_u8(b),
linear_f32_from_linear_u8(a),
)
}

Expand Down Expand Up @@ -83,6 +83,15 @@ impl Hsva {
}
}

#[inline]
pub fn from_additive_srgb([r, g, b]: [u8; 3]) -> Self {
Self::from_additive_rgb([
linear_f32_from_gamma_u8(r),
linear_f32_from_gamma_u8(g),
linear_f32_from_gamma_u8(b),
])
}

#[inline]
pub fn from_rgb(rgb: [f32; 3]) -> Self {
let (h, s, v) = hsv_from_rgb(rgb);
Expand Down Expand Up @@ -131,6 +140,8 @@ impl Hsva {
}
}

/// To linear space rgba in 0-1 range.
///
/// Represents additive colors using a negative alpha.
#[inline]
pub fn to_rgba_unmultiplied(&self) -> [f32; 4] {
Expand All @@ -150,6 +161,7 @@ impl Hsva {
]
}

/// To gamma-space 0-255.
#[inline]
pub fn to_srgba_unmultiplied(&self) -> [u8; 4] {
let [r, g, b, a] = self.to_rgba_unmultiplied();
Expand Down
54 changes: 54 additions & 0 deletions crates/egui/src/style.rs
Original file line number Diff line number Diff line change
Expand Up @@ -829,6 +829,9 @@ pub struct Visuals {

/// Show a spinner when loading an image.
pub image_loading_spinners: bool,

/// How to display numeric color values.
pub numeric_color_space: NumericColorSpace,
}

impl Visuals {
Expand Down Expand Up @@ -1149,6 +1152,8 @@ impl Visuals {
interact_cursor: None,

image_loading_spinners: true,

numeric_color_space: NumericColorSpace::GammaByte,
}
}

Expand Down Expand Up @@ -1711,6 +1716,8 @@ impl Visuals {
interact_cursor,

image_loading_spinners,

numeric_color_space,
} = self;

ui.collapsing("Background Colors", |ui| {
Expand Down Expand Up @@ -1791,6 +1798,11 @@ impl Visuals {
ui.checkbox(image_loading_spinners, "Image loading spinners")
.on_hover_text("Show a spinner when an Image is loading");

ui.horizontal(|ui| {
ui.label("Color picker type:");
numeric_color_space.toggle_button_ui(ui);
});

ui.vertical_centered(|ui| reset_button(ui, self));
}
}
Expand Down Expand Up @@ -1918,3 +1930,45 @@ impl HandleShape {
});
}
}

/// How to display numeric color values.
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
#[cfg_attr(feature = "serde", derive(serde::Deserialize, serde::Serialize))]
pub enum NumericColorSpace {
/// RGB is 0-255 in gamma space.
///
/// Alpha is 0-255 in linear space .
GammaByte,

/// 0-1 in linear space.
Linear,
// TODO(emilk): add Hex as an option
}

impl NumericColorSpace {
pub fn toggle_button_ui(&mut self, ui: &mut Ui) -> crate::Response {
let tooltip = match self {
Self::GammaByte => "Showing color values in 0-255 gamma space",
Self::Linear => "Showing color values in 0-1 linear space",
};

let mut response = ui.button(self.to_string()).on_hover_text(tooltip);
if response.clicked() {
*self = match self {
Self::GammaByte => Self::Linear,
Self::Linear => Self::GammaByte,
};
response.mark_changed();
}
response
}
}

impl std::fmt::Display for NumericColorSpace {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
NumericColorSpace::GammaByte => write!(f, "U8"),
NumericColorSpace::Linear => write!(f, "F"),
}
}
}
Loading
Loading