summaryrefslogtreecommitdiffstats
path: root/wgpu/src/renderer/button.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2019-10-08 03:13:41 +0200
committerLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2019-10-08 03:13:41 +0200
commit10e10e5e06841574425d2633f1c2916733f7b4ff (patch)
tree0407a0136973a201fe44bfc1a94268544a2f8eb5 /wgpu/src/renderer/button.rs
parenta0234d5bcea5b25f575af01d3a8e0296b2d0395c (diff)
downloadiced-10e10e5e06841574425d2633f1c2916733f7b4ff.tar.gz
iced-10e10e5e06841574425d2633f1c2916733f7b4ff.tar.bz2
iced-10e10e5e06841574425d2633f1c2916733f7b4ff.zip
Make `iced_core::Button` customizable
Now it supports: - Any kind of content - Custom border radius - Custom background
Diffstat (limited to 'wgpu/src/renderer/button.rs')
-rw-r--r--wgpu/src/renderer/button.rs45
1 files changed, 26 insertions, 19 deletions
diff --git a/wgpu/src/renderer/button.rs b/wgpu/src/renderer/button.rs
index f75b44f7..00fcd0eb 100644
--- a/wgpu/src/renderer/button.rs
+++ b/wgpu/src/renderer/button.rs
@@ -1,22 +1,26 @@
-use crate::{Background, Primitive, Renderer};
-use iced_native::{button, Button, Color, Layout, Length, Node, Point, Style};
+use crate::{Primitive, Renderer};
+use iced_native::{
+ button, Align, Background, Button, Color, Layout, Length, Node, Point,
+ Style,
+};
impl button::Renderer for Renderer {
- fn node<Message>(&self, button: &Button<Message>) -> Node {
+ fn node<Message>(&self, button: &Button<Message, Self>) -> Node {
let style = Style::default()
.width(button.width)
- .min_height(Length::Units(30))
+ .padding(button.padding)
.min_width(Length::Units(100))
- .align_self(button.align_self);
+ .align_self(button.align_self)
+ .align_items(Align::Stretch);
- Node::new(style)
+ Node::with_children(style, vec![button.content.node(self)])
}
fn draw<Message>(
&mut self,
- button: &Button<Message>,
+ button: &Button<Message, Self>,
layout: Layout<'_>,
- _cursor_position: Point,
+ cursor_position: Point,
) -> Self::Primitive {
let bounds = layout.bounds();
@@ -24,18 +28,21 @@ impl button::Renderer for Renderer {
primitives: vec![
Primitive::Quad {
bounds,
- background: Background::Color(Color {
- r: 0.8,
- b: 0.8,
- g: 0.8,
- a: 1.0,
- }),
- },
- Primitive::Text {
- content: button.label.clone(),
- size: 20.0,
- bounds: layout.bounds(),
+ background: button.background.unwrap_or(Background::Color(
+ Color {
+ r: 0.8,
+ b: 0.8,
+ g: 0.8,
+ a: 1.0,
+ },
+ )),
+ border_radius: button.border_radius,
},
+ button.content.draw(
+ self,
+ layout.children().next().unwrap(),
+ cursor_position,
+ ),
],
}
}