summaryrefslogtreecommitdiff
path: root/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 /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 'components/lazyimage.cpp')
-rw-r--r--components/lazyimage.cpp48
1 files changed, 0 insertions, 48 deletions
diff --git a/components/lazyimage.cpp b/components/lazyimage.cpp
deleted file mode 100644
index 49bbdeb..0000000
--- a/components/lazyimage.cpp
+++ /dev/null
@@ -1,48 +0,0 @@
-#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;
-}