Revert "setting these two to do the same"

This reverts commit ba25cee53f
This commit is contained in:
Chris Cochrun 2023-10-11 20:22:26 +00:00
parent ba25cee53f
commit a0a8400d16
2 changed files with 398 additions and 405 deletions

View file

@ -2,6 +2,10 @@
// of whether or not a file exists
#[cxx_qt::bridge]
mod file_helper {
use rfd::FileDialog;
use std::path::Path;
use tracing::{debug, debug_span, error, info, instrument};
unsafe extern "C++" {
include!("cxx-qt-lib/qstring.h");
type QString = cxx_qt_lib::QString;
@ -11,47 +15,44 @@ mod file_helper {
type QVariant = cxx_qt_lib::QVariant;
}
unsafe extern "RustQt" {
#[qobject]
#[qml_element]
#[qproperty(QString, name)]
#[qproperty(QString, file_path)]
type FileHelper = super::FileHelperRust;
#[qinvokable]
fn validate(self: Pin<&mut FileHelper>, file: QUrl) -> bool;
#[qinvokable]
pub fn save_file(self: Pin<&mut FileHelper>) -> QUrl;
#[qinvokable]
fn load_file(
self: Pin<&mut FileHelper>,
title: QString,
filter: QString,
) -> QUrl;
}
}
use rfd::FileDialog;
use std::path::Path;
use tracing::{debug, debug_span, error, info, instrument};
#[derive(Clone)]
pub struct FileHelperRust {
#[derive(Clone)]
#[cxx_qt::qobject]
pub struct FileHelper {
#[qproperty]
name: QString,
#[qproperty]
file_path: QString,
}
}
impl Default for FileHelperRust {
impl Default for FileHelper {
fn default() -> Self {
Self {
name: QString::from(""),
file_path: QString::from(""),
}
}
}
}
impl ffi::FileHelperRust {
impl qobject::FileHelper {
// #[qinvokable]
// pub fn save(self: Pin<&mut Self>, file: QUrl, service_list: QVariant) -> bool {
// println!("{}", file);
// match service_list.value() {
// QVariantValue::<QString>(..) => println!("string"),
// QVariantValue::<QUrl>(..) => println!("url"),
// QVariantValue::<QDate>(..) => println!("date"),
// _ => println!("QVariant is..."),
// }
// return true;
// }
#[qinvokable]
pub fn load(self: Pin<&mut Self>, file: QUrl) -> Vec<String> {
println!("{file}");
vec!["hi".to_string()]
}
#[qinvokable]
pub fn validate(self: Pin<&mut Self>, file: QUrl) -> bool {
let file_string = file.to_string();
let file_string = file_string.strip_prefix("file://");
@ -62,13 +63,15 @@ impl ffi::FileHelperRust {
exists
}
None => {
let exists = Path::new(&file.to_string()).exists();
let exists =
Path::new(&file.to_string()).exists();
println!("{file} exists? {exists}");
exists
}
}
}
#[qinvokable]
pub fn save_file(self: Pin<&mut Self>) -> QUrl {
let file = FileDialog::new()
.set_file_name("NVTFC.pres")
@ -89,16 +92,19 @@ impl ffi::FileHelperRust {
}
}
#[qinvokable]
pub fn load_file(
self: Pin<&mut Self>,
title: QString,
filter: QString,
) -> QUrl {
let video_filters = [
"mp4", "webm", "avi", "mkv", "MP4", "WEBM", "AVI", "MKV",
"mp4", "webm", "avi", "mkv", "MP4", "WEBM", "AVI",
"MKV",
];
let image_filters = [
"jpg", "png", "gif", "jpeg", "JPG", "PNG", "webp", "gif",
"jpg", "png", "gif", "jpeg", "JPG", "PNG", "webp",
"gif",
];
let audio_filters = ["mp3", "opus", "ogg", "flac", "wav"];
let title = title.to_string();
@ -131,4 +137,5 @@ impl ffi::FileHelperRust {
QUrl::default()
}
}
}
}

View file

@ -1,5 +1,9 @@
#[cxx_qt::bridge]
mod slide_obj {
// use cxx_qt_lib::QVariantValue;
// use std::path::Path;
// use std::task::Context;
unsafe extern "C++" {
include!("cxx-qt-lib/qstring.h");
type QString = cxx_qt_lib::QString;
@ -10,96 +14,55 @@ mod slide_obj {
type QVariant = cxx_qt_lib::QVariant;
}
unsafe extern "RustQt" {
#[qobject]
#[qml_element]
#[qproperty(i32, slide_index)]
#[qproperty(i32, slide_size)]
#[qproperty(i32, image_count)]
#[qproperty(bool, is_playing)]
#[qproperty(bool, looping)]
#[qproperty(QString, text)]
#[qproperty(QString, ty)]
#[qproperty(QString, audio)]
#[qproperty(QString, image_background)]
#[qproperty(QString, video_background)]
#[qproperty(QString, html)]
#[qproperty(QString, vtext_alignment)]
#[qproperty(QString, htext_alignment)]
#[qproperty(QString, font)]
#[qproperty(i32, font_size)]
#[qproperty(f32, video_start_time)]
#[qproperty(f32, video_end_time)]
type SlideObj = super::SlideObjectRust;
#[qsignal]
fn playing_changed(
self: Pin<&mut SlideObj>,
is_playing: bool,
);
#[qsignal]
fn slide_index_changed(
self: Pin<&mut SlideObj>,
slide_index: i32,
);
#[qsignal]
fn slide_size_changed(
self: Pin<&mut SlideObj>,
slide_size: i32,
);
#[qsignal]
fn slide_changed(self: Pin<&mut SlideObj>, slide: i32);
#[qsignal]
fn loop_changed(self: Pin<&mut SlideObj>, looping: bool);
#[qinvokable]
fn change_slide(
self: Pin<&mut SlideObj>,
item: QMap_QString_QVariant,
index: i32,
);
#[qinvokable]
fn next(
self: Pin<&mut SlideObj>,
next_item: QMap_QString_QVariant,
) -> bool;
#[qinvokable]
fn previous(
self: Pin<&mut SlideObj>,
prev_item: QMap_QString_QVariant,
) -> bool;
#[qinvokable]
fn play(self: Pin<&mut SlideObj>) -> bool;
#[qinvokable]
fn pause(self: Pin<&mut SlideObj>) -> bool;
#[qinvokable]
fn play_pause(self: Pin<&mut SlideObj>) -> bool;
#[cxx_qt::qsignals(SlideObj)]
pub enum Signals<'a> {
PlayingChanged { is_playing: &'a bool },
SlideIndexChanged { slide_index: &'a i32 },
SlideSizeChanged { slide_size: &'a i32 },
SlideChanged { slide: &'a i32 },
LoopChanged { looping: &'a bool },
}
}
#[derive(Clone, Debug)]
pub struct SlideObjectRust {
#[derive(Clone, Debug)]
#[cxx_qt::qobject]
pub struct SlideObj {
#[qproperty]
slide_index: i32,
#[qproperty]
slide_size: i32,
#[qproperty]
image_count: i32,
#[qproperty]
is_playing: bool,
#[qproperty]
looping: bool,
#[qproperty]
text: QString,
#[qproperty]
ty: QString,
#[qproperty]
audio: QString,
#[qproperty]
image_background: QString,
#[qproperty]
video_background: QString,
#[qproperty]
html: QString,
#[qproperty]
vtext_alignment: QString,
#[qproperty]
htext_alignment: QString,
#[qproperty]
font: QString,
#[qproperty]
font_size: i32,
#[qproperty]
video_start_time: f32,
#[qproperty]
video_end_time: f32,
}
}
impl Default for SlideObjectRust {
impl Default for SlideObj {
fn default() -> Self {
Self {
slide_index: 0,
@ -121,9 +84,10 @@ impl Default for SlideObjectRust {
video_end_time: 0.0,
}
}
}
}
impl ffi::SlideObjectRust {
impl qobject::SlideObj {
#[qinvokable]
pub fn change_slide(
mut self: Pin<&mut Self>,
item: QMap_QString_QVariant,
@ -170,9 +134,12 @@ impl ffi::SlideObjectRust {
if let Some(image_background) =
image_background.value::<QString>()
{
if &image_background != self.as_ref().image_background() {
if &image_background
!= self.as_ref().image_background()
{
println!("image-bg: {image_background}");
self.as_mut().set_image_background(image_background);
self.as_mut()
.set_image_background(image_background);
}
} else {
println!("image-bg: empty");
@ -183,16 +150,19 @@ impl ffi::SlideObjectRust {
if let Some(video_background) =
video_background.value::<QString>()
{
if &video_background != self.as_ref().video_background() {
if &video_background
!= self.as_ref().video_background()
{
println!("video-bg: {video_background}");
self.as_mut().set_video_background(video_background);
self.as_mut()
.set_video_background(video_background);
}
} else {
println!("video-bg: empty");
}
let font = item
.get(&QString::from("font"))
.unwrap_or(QVariant::from(&QString::from("Quicksand")));
let font = item.get(&QString::from("font")).unwrap_or(
QVariant::from(&QString::from("Quicksand")),
);
if let Some(font) = font.value::<QString>() {
if &font != self.as_ref().font() {
println!("font: {font}");
@ -207,9 +177,13 @@ impl ffi::SlideObjectRust {
if let Some(vtext_alignment) =
vtext_alignment.value::<QString>()
{
if &vtext_alignment != self.as_ref().vtext_alignment() {
println!("vertical-text-align: {vtext_alignment}");
self.as_mut().set_vtext_alignment(vtext_alignment);
if &vtext_alignment != self.as_ref().vtext_alignment()
{
println!(
"vertical-text-align: {vtext_alignment}"
);
self.as_mut()
.set_vtext_alignment(vtext_alignment);
}
} else {
println!("vertical-text-align: empty");
@ -220,9 +194,13 @@ impl ffi::SlideObjectRust {
if let Some(htext_alignment) =
htext_alignment.value::<QString>()
{
if &htext_alignment != self.as_ref().htext_alignment() {
println!("horizontal-text-align: {htext_alignment}");
self.as_mut().set_htext_alignment(htext_alignment);
if &htext_alignment != self.as_ref().htext_alignment()
{
println!(
"horizontal-text-align: {htext_alignment}"
);
self.as_mut()
.set_htext_alignment(htext_alignment);
}
} else {
println!("horizontal-text-align: empty");
@ -246,7 +224,8 @@ impl ffi::SlideObjectRust {
println!("looping: {looping}");
self.as_mut().set_looping(looping);
let lp = looping;
self.as_mut().loop_changed(&lp);
self.as_mut()
.emit(Signals::LoopChanged { looping: &lp });
}
} else {
println!("looping: empty")
@ -279,10 +258,12 @@ impl ffi::SlideObjectRust {
println!("New slide index = {}", int);
self.as_mut().set_slide_index(int);
};
self.as_mut().slide_changed(&index);
self.as_mut()
.emit(Signals::SlideChanged { slide: &index });
println!("## Slide End ##");
}
#[qinvokable]
pub fn next(
mut self: Pin<&mut Self>,
next_item: QMap_QString_QVariant,
@ -291,6 +272,7 @@ impl ffi::SlideObjectRust {
self.as_mut().change_slide(next_item, new_id);
true
}
#[qinvokable]
pub fn previous(
mut self: Pin<&mut Self>,
prev_item: QMap_QString_QVariant,
@ -299,23 +281,27 @@ impl ffi::SlideObjectRust {
self.as_mut().change_slide(prev_item, new_id);
true
}
#[qinvokable]
pub fn play(mut self: Pin<&mut Self>) -> bool {
self.as_mut().set_is_playing(true);
self.as_mut().playing_changed(&true);
self.as_mut().emit_playing_changed(&true);
true
}
#[qinvokable]
pub fn pause(mut self: Pin<&mut Self>) -> bool {
self.as_mut().set_is_playing(false);
self.as_mut().playing_changed(&false);
self.as_mut().emit_playing_changed(&false);
false
}
#[qinvokable]
pub fn play_pause(mut self: Pin<&mut Self>) -> bool {
let playing = self.as_ref().is_playing().clone();
match playing {
true => self.as_mut().set_is_playing(false),
false => self.as_mut().set_is_playing(true),
}
self.as_mut().playing_changed(&!playing);
self.as_mut().emit_playing_changed(&!playing);
!playing
}
}
}