diff options
author | ouwou <26526779+ouwou@users.noreply.github.com> | 2021-11-28 22:48:30 -0500 |
---|---|---|
committer | ouwou <26526779+ouwou@users.noreply.github.com> | 2021-11-28 22:48:30 -0500 |
commit | e1703aea3fd597b23bde90e6c505278c517be611 (patch) | |
tree | 37d98fc90c9cd0844388bfb79beda2204f44af92 /src/components/lazyimage.cpp | |
parent | fd53a76bf6f53a095a639765923a30f2206b2cd6 (diff) | |
parent | e02107feea8214a045e6faa969f00dcbc0d2b072 (diff) | |
download | abaddon-portaudio-e1703aea3fd597b23bde90e6c505278c517be611.tar.gz abaddon-portaudio-e1703aea3fd597b23bde90e6c505278c517be611.zip |
merge master
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; +} |