summaryrefslogtreecommitdiff
path: root/src/components/lazyimage.cpp
diff options
context:
space:
mode:
authorDylam De La Torre <DyXel04@gmail.com>2021-11-23 05:21:56 +0100
committerGitHub <noreply@github.com>2021-11-23 04:21:56 +0000
commita51a54bc5979a2491f152abc47ad54e6b63f27c8 (patch)
treece67092b2f6df366033a65a6111e4650866766b2 /src/components/lazyimage.cpp
parentd88079000a79e6bcbe51c5a2868d57b303b5fcb6 (diff)
downloadabaddon-portaudio-a51a54bc5979a2491f152abc47ad54e6b63f27c8.tar.gz
abaddon-portaudio-a51a54bc5979a2491f152abc47ad54e6b63f27c8.zip
Restructure source and resource files (#46)
importantly, res is now res/res and css is now res/css
Diffstat (limited to 'src/components/lazyimage.cpp')
-rw-r--r--src/components/lazyimage.cpp48
1 files changed, 48 insertions, 0 deletions
diff --git a/src/components/lazyimage.cpp b/src/components/lazyimage.cpp
new file mode 100644
index 0000000..49bbdeb
--- /dev/null
+++ b/src/components/lazyimage.cpp
@@ -0,0 +1,48 @@
+#include "lazyimage.hpp"
+#include "abaddon.hpp"
+
+LazyImage::LazyImage(int w, int h, bool use_placeholder)
+ : m_width(w)
+ , m_height(h) {
+ if (use_placeholder)
+ property_pixbuf() = Abaddon::Get().GetImageManager().GetPlaceholder(w)->scale_simple(w, h, Gdk::INTERP_BILINEAR);
+ signal_draw().connect(sigc::mem_fun(*this, &LazyImage::OnDraw));
+}
+
+LazyImage::LazyImage(const std::string &url, int w, int h, bool use_placeholder)
+ : m_url(url)
+ , m_width(w)
+ , m_height(h) {
+ if (use_placeholder)
+ property_pixbuf() = Abaddon::Get().GetImageManager().GetPlaceholder(w)->scale_simple(w, h, Gdk::INTERP_BILINEAR);
+ signal_draw().connect(sigc::mem_fun(*this, &LazyImage::OnDraw));
+}
+
+void LazyImage::SetAnimated(bool is_animated) {
+ m_animated = is_animated;
+}
+
+void LazyImage::SetURL(const std::string &url) {
+ m_url = url;
+}
+
+bool LazyImage::OnDraw(const Cairo::RefPtr<Cairo::Context> &context) {
+ if (!m_needs_request || m_url == "") return false;
+ m_needs_request = false;
+
+ if (m_animated) {
+ auto cb = [this](const Glib::RefPtr<Gdk::PixbufAnimation> &pb) {
+ property_pixbuf_animation() = pb;
+ };
+
+ Abaddon::Get().GetImageManager().LoadAnimationFromURL(m_url, m_width, m_height, sigc::track_obj(cb, *this));
+ } else {
+ auto cb = [this](const Glib::RefPtr<Gdk::Pixbuf> &pb) {
+ property_pixbuf() = pb->scale_simple(m_width, m_height, Gdk::INTERP_BILINEAR);
+ };
+
+ Abaddon::Get().GetImageManager().LoadFromURL(m_url, sigc::track_obj(cb, *this));
+ }
+
+ return false;
+}