diff options
author | Dylam De La Torre <DyXel04@gmail.com> | 2021-11-23 05:21:56 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-11-23 04:21:56 +0000 |
commit | a51a54bc5979a2491f152abc47ad54e6b63f27c8 (patch) | |
tree | ce67092b2f6df366033a65a6111e4650866766b2 /src/components/lazyimage.cpp | |
parent | d88079000a79e6bcbe51c5a2868d57b303b5fcb6 (diff) | |
download | abaddon-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.cpp | 48 |
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; +} |