Skip to content

Commit 1e11239

Browse files
authored
Merge branch 'GraphiteEditor:master' into hierarchical-tree
2 parents dcfbb97 + 0c3cae2 commit 1e11239

File tree

83 files changed

+3690
-2200
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

83 files changed

+3690
-2200
lines changed

demo-artwork/changing-seasons.graphite

+1-1
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

demo-artwork/procedural-string-lights.graphite

+1-1
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

editor/Cargo.toml

+6-1
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,9 @@ ron = ["dep:ron"]
3030
# Local dependencies
3131
graphite-proc-macros = { path = "../proc-macros" }
3232
graph-craft = { path = "../node-graph/graph-craft" }
33-
interpreted-executor = { path = "../node-graph/interpreted-executor", features = ["serde"] }
33+
interpreted-executor = { path = "../node-graph/interpreted-executor", features = [
34+
"serde",
35+
] }
3436
graphene-core = { path = "../node-graph/gcore" }
3537
graphene-std = { path = "../node-graph/gstd", features = ["serde"] }
3638

@@ -58,6 +60,9 @@ web-sys = { workspace = true, features = [
5860
"Element",
5961
"HtmlCanvasElement",
6062
"CanvasRenderingContext2d",
63+
"CanvasPattern",
64+
"OffscreenCanvas",
65+
"OffscreenCanvasRenderingContext2d",
6166
"TextMetrics",
6267
] }
6368

editor/src/messages/dialog/simple_dialogs/about_graphite_dialog.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -20,8 +20,9 @@ impl DialogLayoutHolder for AboutGraphiteDialog {
2020

2121
fn layout_column_2(&self) -> Layout {
2222
let links = [
23-
("Website", "Website", "https://graphite.rs"),
23+
("Heart", "Donate", "https://graphite.rs/donate/"),
2424
("Volunteer", "Volunteer", "https://graphite.rs/volunteer/"),
25+
("GraphiteLogo", "Website", "https://graphite.rs"),
2526
("Credits", "Credits", "https://github.com/GraphiteEditor/Graphite/graphs/contributors"),
2627
];
2728
let mut widgets = links

editor/src/messages/input_mapper/input_mappings.rs

+1
Original file line numberDiff line numberDiff line change
@@ -282,6 +282,7 @@ pub fn input_mappings() -> Mapping {
282282
entry!(KeyDown(Enter); action_dispatch=SplineToolMessage::Confirm),
283283
//
284284
// FillToolMessage
285+
entry!(PointerMove; refresh_keys=[Shift], action_dispatch=FillToolMessage::PointerMove),
285286
entry!(KeyDown(MouseLeft); action_dispatch=FillToolMessage::FillPrimaryColor),
286287
entry!(KeyDown(MouseLeft); modifiers=[Shift], action_dispatch=FillToolMessage::FillSecondaryColor),
287288
entry!(KeyUp(MouseLeft); action_dispatch=FillToolMessage::PointerUp),

editor/src/messages/layout/layout_message_handler.rs

+5-5
Original file line numberDiff line numberDiff line change
@@ -276,13 +276,13 @@ impl LayoutMessageHandler {
276276

277277
responses.add(callback_message);
278278
}
279-
Widget::PivotInput(pivot_input) => {
279+
Widget::ReferencePointInput(reference_point_input) => {
280280
let callback_message = match action {
281-
WidgetValueAction::Commit => (pivot_input.on_commit.callback)(&()),
281+
WidgetValueAction::Commit => (reference_point_input.on_commit.callback)(&()),
282282
WidgetValueAction::Update => {
283-
let update_value = value.as_str().expect("PivotInput update was not of type: u64");
284-
pivot_input.position = update_value.into();
285-
(pivot_input.on_update.callback)(pivot_input)
283+
let update_value = value.as_str().expect("ReferencePointInput update was not of type: u64");
284+
reference_point_input.value = update_value.into();
285+
(reference_point_input.on_update.callback)(reference_point_input)
286286
}
287287
};
288288

editor/src/messages/layout/utility_types/layout_widget.rs

+3-3
Original file line numberDiff line numberDiff line change
@@ -373,7 +373,7 @@ impl LayoutGroup {
373373
Widget::TextInput(x) => &mut x.tooltip,
374374
Widget::TextLabel(x) => &mut x.tooltip,
375375
Widget::BreadcrumbTrailButtons(x) => &mut x.tooltip,
376-
Widget::InvisibleStandinInput(_) | Widget::PivotInput(_) | Widget::RadioInput(_) | Widget::Separator(_) | Widget::WorkingColorsInput(_) | Widget::NodeCatalog(_) => continue,
376+
Widget::InvisibleStandinInput(_) | Widget::ReferencePointInput(_) | Widget::RadioInput(_) | Widget::Separator(_) | Widget::WorkingColorsInput(_) | Widget::NodeCatalog(_) => continue,
377377
};
378378
if val.is_empty() {
379379
val.clone_from(&tooltip);
@@ -546,7 +546,7 @@ pub enum Widget {
546546
NodeCatalog(NodeCatalog),
547547
NumberInput(NumberInput),
548548
ParameterExposeButton(ParameterExposeButton),
549-
PivotInput(PivotInput),
549+
ReferencePointInput(ReferencePointInput),
550550
PopoverButton(PopoverButton),
551551
RadioInput(RadioInput),
552552
Separator(Separator),
@@ -621,7 +621,7 @@ impl DiffUpdate {
621621
| Widget::CurveInput(_)
622622
| Widget::InvisibleStandinInput(_)
623623
| Widget::NodeCatalog(_)
624-
| Widget::PivotInput(_)
624+
| Widget::ReferencePointInput(_)
625625
| Widget::RadioInput(_)
626626
| Widget::Separator(_)
627627
| Widget::TextAreaInput(_)

editor/src/messages/layout/utility_types/widgets/input_widgets.rs

+4-86
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,9 @@
11
use crate::messages::input_mapper::utility_types::misc::ActionKeys;
22
use crate::messages::layout::utility_types::widget_prelude::*;
33
use derivative::*;
4-
use glam::DVec2;
54
use graphene_core::Color;
65
use graphene_core::raster::curve::Curve;
6+
use graphene_std::transform::ReferencePoint;
77
use graphite_proc_macros::WidgetBuilder;
88

99
#[derive(Clone, Derivative, serde::Serialize, serde::Deserialize, WidgetBuilder, specta::Type)]
@@ -411,100 +411,18 @@ pub struct CurveInput {
411411

412412
#[derive(Clone, Default, Derivative, serde::Serialize, serde::Deserialize, WidgetBuilder, specta::Type)]
413413
#[derivative(Debug, PartialEq)]
414-
pub struct PivotInput {
414+
pub struct ReferencePointInput {
415415
#[widget_builder(constructor)]
416-
pub position: PivotPosition,
416+
pub value: ReferencePoint,
417417

418418
pub disabled: bool,
419419

420420
// Callbacks
421421
#[serde(skip)]
422422
#[derivative(Debug = "ignore", PartialEq = "ignore")]
423-
pub on_update: WidgetCallback<PivotInput>,
423+
pub on_update: WidgetCallback<ReferencePointInput>,
424424

425425
#[serde(skip)]
426426
#[derivative(Debug = "ignore", PartialEq = "ignore")]
427427
pub on_commit: WidgetCallback<()>,
428428
}
429-
430-
#[derive(Clone, Copy, serde::Serialize, serde::Deserialize, Debug, Default, PartialEq, Eq, specta::Type)]
431-
pub enum PivotPosition {
432-
#[default]
433-
None,
434-
TopLeft,
435-
TopCenter,
436-
TopRight,
437-
CenterLeft,
438-
Center,
439-
CenterRight,
440-
BottomLeft,
441-
BottomCenter,
442-
BottomRight,
443-
}
444-
445-
impl From<&str> for PivotPosition {
446-
fn from(input: &str) -> Self {
447-
match input {
448-
"None" => PivotPosition::None,
449-
"TopLeft" => PivotPosition::TopLeft,
450-
"TopCenter" => PivotPosition::TopCenter,
451-
"TopRight" => PivotPosition::TopRight,
452-
"CenterLeft" => PivotPosition::CenterLeft,
453-
"Center" => PivotPosition::Center,
454-
"CenterRight" => PivotPosition::CenterRight,
455-
"BottomLeft" => PivotPosition::BottomLeft,
456-
"BottomCenter" => PivotPosition::BottomCenter,
457-
"BottomRight" => PivotPosition::BottomRight,
458-
_ => panic!("Failed parsing unrecognized PivotPosition enum value '{input}'"),
459-
}
460-
}
461-
}
462-
463-
impl From<PivotPosition> for Option<DVec2> {
464-
fn from(input: PivotPosition) -> Self {
465-
match input {
466-
PivotPosition::None => None,
467-
PivotPosition::TopLeft => Some(DVec2::new(0., 0.)),
468-
PivotPosition::TopCenter => Some(DVec2::new(0.5, 0.)),
469-
PivotPosition::TopRight => Some(DVec2::new(1., 0.)),
470-
PivotPosition::CenterLeft => Some(DVec2::new(0., 0.5)),
471-
PivotPosition::Center => Some(DVec2::new(0.5, 0.5)),
472-
PivotPosition::CenterRight => Some(DVec2::new(1., 0.5)),
473-
PivotPosition::BottomLeft => Some(DVec2::new(0., 1.)),
474-
PivotPosition::BottomCenter => Some(DVec2::new(0.5, 1.)),
475-
PivotPosition::BottomRight => Some(DVec2::new(1., 1.)),
476-
}
477-
}
478-
}
479-
480-
impl From<DVec2> for PivotPosition {
481-
fn from(input: DVec2) -> Self {
482-
const TOLERANCE: f64 = 1e-5_f64;
483-
if input.y.abs() < TOLERANCE {
484-
if input.x.abs() < TOLERANCE {
485-
return PivotPosition::TopLeft;
486-
} else if (input.x - 0.5).abs() < TOLERANCE {
487-
return PivotPosition::TopCenter;
488-
} else if (input.x - 1.).abs() < TOLERANCE {
489-
return PivotPosition::TopRight;
490-
}
491-
} else if (input.y - 0.5).abs() < TOLERANCE {
492-
if input.x.abs() < TOLERANCE {
493-
return PivotPosition::CenterLeft;
494-
} else if (input.x - 0.5).abs() < TOLERANCE {
495-
return PivotPosition::Center;
496-
} else if (input.x - 1.).abs() < TOLERANCE {
497-
return PivotPosition::CenterRight;
498-
}
499-
} else if (input.y - 1.).abs() < TOLERANCE {
500-
if input.x.abs() < TOLERANCE {
501-
return PivotPosition::BottomLeft;
502-
} else if (input.x - 0.5).abs() < TOLERANCE {
503-
return PivotPosition::BottomCenter;
504-
} else if (input.x - 1.).abs() < TOLERANCE {
505-
return PivotPosition::BottomRight;
506-
}
507-
}
508-
PivotPosition::None
509-
}
510-
}

editor/src/messages/portfolio/document/document_message_handler.rs

+9-9
Original file line numberDiff line numberDiff line change
@@ -2802,7 +2802,7 @@ mod document_message_handler_tests {
28022802
let document = editor.active_document();
28032803
for layer in document.metadata().all_layers() {
28042804
if let Some(bbox) = document.metadata().bounding_box_viewport(layer) {
2805-
if (bbox[0].x - min_x).abs() < 1.0 && (bbox[0].y - min_y).abs() < 1.0 {
2805+
if (bbox[0].x - min_x).abs() < 1. && (bbox[0].y - min_y).abs() < 1. {
28062806
return Some(layer);
28072807
}
28082808
}
@@ -2816,8 +2816,8 @@ mod document_message_handler_tests {
28162816
parent.children(document.metadata()).position(|child| child == layer)
28172817
}
28182818

2819-
let layer_middle = get_layer_by_bounds(&mut editor, 50.0, 50.0).await.unwrap();
2820-
let layer_top = get_layer_by_bounds(&mut editor, 100.0, 100.0).await.unwrap();
2819+
let layer_middle = get_layer_by_bounds(&mut editor, 50., 50.).await.unwrap();
2820+
let layer_top = get_layer_by_bounds(&mut editor, 100., 100.).await.unwrap();
28212821

28222822
let initial_index_top = get_layer_index(&mut editor, layer_top).await.unwrap();
28232823
let initial_index_middle = get_layer_index(&mut editor, layer_middle).await.unwrap();
@@ -2917,7 +2917,7 @@ mod document_message_handler_tests {
29172917
// Applying transform to folder1 (translation)
29182918
editor.handle_message(NodeGraphMessage::SelectedNodesSet { nodes: vec![folder1.to_node()] }).await;
29192919
editor.handle_message(TransformLayerMessage::BeginGrab).await;
2920-
editor.move_mouse(100.0, 50.0, ModifierKeys::empty(), MouseKeys::NONE).await;
2920+
editor.move_mouse(100., 50., ModifierKeys::empty(), MouseKeys::NONE).await;
29212921
editor
29222922
.handle_message(TransformLayerMessage::PointerMove {
29232923
slow_key: Key::Shift,
@@ -2929,7 +2929,7 @@ mod document_message_handler_tests {
29292929
// Applying different transform to folder2 (translation)
29302930
editor.handle_message(NodeGraphMessage::SelectedNodesSet { nodes: vec![folder2.to_node()] }).await;
29312931
editor.handle_message(TransformLayerMessage::BeginGrab).await;
2932-
editor.move_mouse(200.0, 100.0, ModifierKeys::empty(), MouseKeys::NONE).await;
2932+
editor.move_mouse(200., 100., ModifierKeys::empty(), MouseKeys::NONE).await;
29332933
editor
29342934
.handle_message(TransformLayerMessage::PointerMove {
29352935
slow_key: Key::Shift,
@@ -2948,7 +2948,7 @@ mod document_message_handler_tests {
29482948
editor.handle_message(DocumentMessage::MoveSelectedLayersTo { parent: folder1, insert_index: 0 }).await;
29492949

29502950
editor.handle_message(TransformLayerMessage::BeginGrab).await;
2951-
editor.move_mouse(50.0, 25.0, ModifierKeys::empty(), MouseKeys::NONE).await;
2951+
editor.move_mouse(50., 25., ModifierKeys::empty(), MouseKeys::NONE).await;
29522952
editor
29532953
.handle_message(TransformLayerMessage::PointerMove {
29542954
slow_key: Key::Shift,
@@ -2969,10 +2969,10 @@ mod document_message_handler_tests {
29692969
let rect_bbox_after = document.metadata().bounding_box_viewport(rect_layer).unwrap();
29702970

29712971
// Verifing the rectangle maintains approximately the same position in viewport space
2972-
let before_center = (rect_bbox_before[0] + rect_bbox_before[1]) / 2.0;
2973-
let after_center = (rect_bbox_after[0] + rect_bbox_after[1]) / 2.0;
2972+
let before_center = (rect_bbox_before[0] + rect_bbox_before[1]) / 2.;
2973+
let after_center = (rect_bbox_after[0] + rect_bbox_after[1]) / 2.;
29742974
let distance = before_center.distance(after_center);
29752975

2976-
assert!(distance < 1.0, "Rectangle should maintain its viewport position after moving between transformed groups");
2976+
assert!(distance < 1., "Rectangle should maintain its viewport position after moving between transformed groups");
29772977
}
29782978
}

0 commit comments

Comments
 (0)