feat: Added readme and forgotten id.rs
This commit is contained in:
77
crates/iced-video/examples/minimal.rs
Normal file
77
crates/iced-video/examples/minimal.rs
Normal file
@@ -0,0 +1,77 @@
|
||||
use iced_video::{Video, VideoHandle};
|
||||
|
||||
pub fn main() -> iced::Result {
|
||||
use tracing_subscriber::prelude::*;
|
||||
tracing_subscriber::registry()
|
||||
.with(
|
||||
tracing_subscriber::fmt::layer()
|
||||
.with_thread_ids(true)
|
||||
.with_file(true),
|
||||
)
|
||||
.with(tracing_subscriber::EnvFilter::from_default_env())
|
||||
.init();
|
||||
iced::application(State::new, update, view).run()
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct State {
|
||||
video: VideoHandle,
|
||||
}
|
||||
|
||||
impl State {
|
||||
pub fn new() -> Self {
|
||||
let video = VideoHandle::new("https://jellyfin.tsuba.darksailor.dev/Items/6010382cf25273e624d305907010d773/Download?api_key=036c140222464878862231ef66a2bc9c")
|
||||
.expect("Failed to create video handle");
|
||||
Self { video }
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Copy)]
|
||||
pub enum Message {
|
||||
Play,
|
||||
Pause,
|
||||
Loaded,
|
||||
Load,
|
||||
}
|
||||
|
||||
pub fn update(state: &mut State, message: Message) -> iced::Task<Message> {
|
||||
match message {
|
||||
Message::Load => {
|
||||
// does stuff
|
||||
let src = state.video.source().clone();
|
||||
iced::Task::perform(src.wait(), |_| Message::Loaded)
|
||||
}
|
||||
Message::Play => {
|
||||
state.video.source().play().expect("Failed to play video");
|
||||
iced::Task::none()
|
||||
}
|
||||
Message::Pause => {
|
||||
state.video.source().pause().expect("Failed to pause video");
|
||||
iced::Task::none()
|
||||
}
|
||||
Message::Loaded => {
|
||||
// Video loaded
|
||||
iced::Task::none()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn view<'a>(state: &'a State) -> iced::Element<'a, Message> {
|
||||
let video_widget = Video::new(&state.video)
|
||||
.width(iced::Length::Fill)
|
||||
.height(iced::Length::Fill)
|
||||
.content_fit(iced::ContentFit::Contain);
|
||||
|
||||
iced::widget::Column::new()
|
||||
.push(video_widget)
|
||||
.push(
|
||||
iced::widget::Row::new()
|
||||
.push(iced::widget::Button::new("Play").on_press(Message::Play))
|
||||
.push(iced::widget::Button::new("Pause").on_press(Message::Pause))
|
||||
.spacing(5)
|
||||
.padding(10)
|
||||
.align_y(iced::Alignment::Center),
|
||||
)
|
||||
.align_x(iced::Alignment::Center)
|
||||
.into()
|
||||
}
|
||||
Reference in New Issue
Block a user