2024-01-30 16:26:02 +00:00
|
|
|
use std::path::PathBuf;
|
|
|
|
use std::str::FromStr;
|
|
|
|
use std::sync::Arc;
|
|
|
|
|
2024-01-30 05:56:51 +00:00
|
|
|
use gpui::*;
|
|
|
|
|
|
|
|
#[derive(IntoElement)]
|
2024-01-30 16:26:02 +00:00
|
|
|
struct ImageContainer {
|
2024-01-30 05:56:51 +00:00
|
|
|
text: SharedString,
|
2024-01-30 16:26:02 +00:00
|
|
|
src: ImageSource,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl ImageContainer {
|
|
|
|
pub fn new(text: impl Into<SharedString>, src: impl Into<ImageSource>) -> Self {
|
|
|
|
Self {
|
|
|
|
text: text.into(),
|
|
|
|
src: src.into(),
|
|
|
|
}
|
|
|
|
}
|
2024-01-30 05:56:51 +00:00
|
|
|
}
|
|
|
|
|
2024-01-30 16:26:02 +00:00
|
|
|
impl RenderOnce for ImageContainer {
|
2024-01-30 05:56:51 +00:00
|
|
|
fn render(self, _: &mut WindowContext) -> impl IntoElement {
|
|
|
|
div().child(
|
|
|
|
div()
|
|
|
|
.flex_row()
|
|
|
|
.size_full()
|
|
|
|
.gap_4()
|
|
|
|
.child(self.text)
|
2024-01-30 16:26:02 +00:00
|
|
|
.child(img(self.src).w(px(512.0)).h(px(512.0))),
|
2024-01-30 05:56:51 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct ImageShowcase {
|
2024-01-30 16:26:02 +00:00
|
|
|
local_resource: Arc<PathBuf>,
|
2024-01-30 14:54:23 +00:00
|
|
|
remote_resource: SharedUri,
|
2024-01-30 05:56:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Render for ImageShowcase {
|
|
|
|
fn render(&mut self, _cx: &mut ViewContext<Self>) -> impl IntoElement {
|
|
|
|
div()
|
|
|
|
.flex()
|
|
|
|
.flex_row()
|
|
|
|
.size_full()
|
|
|
|
.justify_center()
|
|
|
|
.items_center()
|
|
|
|
.gap_8()
|
|
|
|
.bg(rgb(0xFFFFFF))
|
2024-01-30 16:26:02 +00:00
|
|
|
.child(ImageContainer::new(
|
|
|
|
"Image loaded from a local file",
|
|
|
|
self.local_resource.clone(),
|
|
|
|
))
|
|
|
|
.child(ImageContainer::new(
|
|
|
|
"Image loaded from a remote resource",
|
|
|
|
self.remote_resource.clone(),
|
|
|
|
))
|
2024-01-30 05:56:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
env_logger::init();
|
|
|
|
|
|
|
|
App::new().run(|cx: &mut AppContext| {
|
|
|
|
cx.open_window(WindowOptions::default(), |cx| {
|
|
|
|
cx.new_view(|_cx| ImageShowcase {
|
2024-02-22 09:47:24 +00:00
|
|
|
// Relative path to your root project path
|
|
|
|
local_resource: Arc::new(PathBuf::from_str("examples/image/app-icon.png").unwrap()),
|
2024-01-30 16:26:02 +00:00
|
|
|
remote_resource: "https://picsum.photos/512/512".into(),
|
2024-01-30 05:56:51 +00:00
|
|
|
})
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|