summaryrefslogtreecommitdiff
path: root/components/lazyimage.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'components/lazyimage.cpp')
-rw-r--r--components/lazyimage.cpp21
1 files changed, 17 insertions, 4 deletions
diff --git a/components/lazyimage.cpp b/components/lazyimage.cpp
index 40d2268..5574c6c 100644
--- a/components/lazyimage.cpp
+++ b/components/lazyimage.cpp
@@ -18,6 +18,10 @@ LazyImage::LazyImage(const std::string &url, int w, int h, bool use_placeholder)
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;
}
@@ -26,10 +30,19 @@ bool LazyImage::OnDraw(const Cairo::RefPtr<Cairo::Context> &context) {
if (!m_needs_request || m_url == "") return false;
m_needs_request = false;
- 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));
+ 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;
}