Streamline RTSurface
and fix potential bug in updateImages()
This commit is contained in:
parent
fe74625d78
commit
363385a838
@ -19,66 +19,110 @@
|
|||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
#include "options.h"
|
|
||||||
#include "rtsurface.h"
|
#include "rtsurface.h"
|
||||||
|
|
||||||
|
#include "options.h"
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
|
|
||||||
std::map<std::string, Cairo::RefPtr<Cairo::ImageSurface>> surfaceCache;
|
using SurfaceCache = std::map<std::string, Cairo::RefPtr<Cairo::ImageSurface>>;
|
||||||
|
|
||||||
|
SurfaceCache surfaceCache;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
double RTSurface::dpiBack = 0.;
|
RTSurface::RTSurface() :
|
||||||
int RTSurface::scaleBack = 0;
|
surface(new Cairo::ImageSurface(nullptr, false))
|
||||||
|
|
||||||
RTSurface::RTSurface () : RTScalable()
|
|
||||||
{
|
{
|
||||||
Cairo::RefPtr<Cairo::ImageSurface> imgSurf(new Cairo::ImageSurface(nullptr, false));
|
|
||||||
surface = imgSurf;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RTSurface::RTSurface(const RTSurface& other) : RTScalable()
|
RTSurface::RTSurface(const Glib::ustring& fileName, const Glib::ustring& rtlFileName) :
|
||||||
|
RTSurface()
|
||||||
{
|
{
|
||||||
surface = other.surface;
|
setImage(fileName, rtlFileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
RTSurface::RTSurface (Glib::ustring fileName, Glib::ustring rtlFileName) : RTScalable()
|
void RTSurface::setImage(const Glib::ustring& fileName, const Glib::ustring& rtlFileName)
|
||||||
{
|
{
|
||||||
Cairo::RefPtr<Cairo::ImageSurface> imgSurf(new Cairo::ImageSurface(nullptr, false));
|
const Glib::ustring& imageName =
|
||||||
surface = imgSurf;
|
!rtlFileName.empty() && getDirection() == Gtk::TEXT_DIR_RTL
|
||||||
setImage (fileName, rtlFileName);
|
? rtlFileName
|
||||||
}
|
: fileName;
|
||||||
|
|
||||||
void RTSurface::setImage (Glib::ustring fileName, Glib::ustring rtlFileName)
|
|
||||||
{
|
|
||||||
Glib::ustring imageName;
|
|
||||||
|
|
||||||
if (!rtlFileName.empty() && getDirection() == Gtk::TEXT_DIR_RTL) {
|
|
||||||
imageName = rtlFileName;
|
|
||||||
} else {
|
|
||||||
imageName = fileName;
|
|
||||||
}
|
|
||||||
|
|
||||||
changeImage (imageName);
|
changeImage (imageName);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RTSurface::setDPInScale (const double newDPI, const int newScale)
|
int RTSurface::getWidth() const
|
||||||
|
{
|
||||||
|
return
|
||||||
|
surface
|
||||||
|
? surface->get_width()
|
||||||
|
: -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int RTSurface::getHeight() const
|
||||||
|
{
|
||||||
|
return
|
||||||
|
surface
|
||||||
|
? surface->get_height()
|
||||||
|
: -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool RTSurface::hasSurface() const
|
||||||
|
{
|
||||||
|
return static_cast<bool>(surface);
|
||||||
|
}
|
||||||
|
|
||||||
|
Cairo::RefPtr<const Cairo::ImageSurface> RTSurface::get() const
|
||||||
|
{
|
||||||
|
return surface;
|
||||||
|
}
|
||||||
|
|
||||||
|
const Cairo::RefPtr<Cairo::ImageSurface>& RTSurface::get()
|
||||||
|
{
|
||||||
|
return surface;
|
||||||
|
}
|
||||||
|
|
||||||
|
void RTSurface::init()
|
||||||
{
|
{
|
||||||
if (getScale() != newScale || (getScale() == 1 && getDPI() != newDPI)) {
|
|
||||||
RTScalable::setDPInScale(newDPI, newScale);
|
|
||||||
dpiBack = getDPI();
|
dpiBack = getDPI();
|
||||||
scaleBack = getScale();
|
scaleBack = getScale();
|
||||||
//printf("RTSurface::setDPInScale : New scale = %d & new DPI = %.3f (%.3f asked) -> Reloading all RTSurface\n", scaleBack, dpiBack, newDPI);
|
}
|
||||||
|
|
||||||
|
void RTSurface::updateImages()
|
||||||
|
{
|
||||||
|
const double tweakedDpi = getTweakedDPI();
|
||||||
|
|
||||||
|
for (auto& entry : surfaceCache) {
|
||||||
|
entry.second = loadImage(entry.first, tweakedDpi);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void RTSurface::setDPInScale(const double newDPI, const int newScale)
|
||||||
|
{
|
||||||
|
if (
|
||||||
|
getScale() != newScale
|
||||||
|
|| (
|
||||||
|
getScale() == 1
|
||||||
|
&& getDPI() != newDPI
|
||||||
|
)
|
||||||
|
) {
|
||||||
|
setDPInScale(newDPI, newScale);
|
||||||
|
dpiBack = getDPI();
|
||||||
|
scaleBack = getScale();
|
||||||
|
|
||||||
updateImages();
|
updateImages();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void RTSurface::changeImage (Glib::ustring imageName)
|
void RTSurface::changeImage(const Glib::ustring& imageName)
|
||||||
{
|
{
|
||||||
auto iterator = surfaceCache.find (imageName);
|
const SurfaceCache::const_iterator iterator = surfaceCache.find(imageName);
|
||||||
|
|
||||||
if (iterator == surfaceCache.end ()) {
|
if (iterator != surfaceCache.end()) {
|
||||||
|
surface = iterator->second;
|
||||||
|
} else {
|
||||||
surface = loadImage(imageName, getTweakedDPI());
|
surface = loadImage(imageName, getTweakedDPI());
|
||||||
|
|
||||||
// HOMBRE: As of now, GDK_SCALE is forced to 1, so setting the Cairo::ImageSurface scale is not required
|
// HOMBRE: As of now, GDK_SCALE is forced to 1, so setting the Cairo::ImageSurface scale is not required
|
||||||
@ -92,53 +136,10 @@ void RTSurface::changeImage (Glib::ustring imageName)
|
|||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
iterator = surfaceCache.emplace (imageName, surface).first;
|
surfaceCache.emplace(imageName, surface);
|
||||||
}
|
|
||||||
|
|
||||||
surface = iterator->second;
|
|
||||||
}
|
|
||||||
|
|
||||||
int RTSurface::getWidth() const
|
|
||||||
{
|
|
||||||
return surface ? surface->get_width() : -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
int RTSurface::getHeight() const
|
|
||||||
{
|
|
||||||
return surface ? surface->get_height() : -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void RTSurface::init()
|
|
||||||
{
|
|
||||||
dpiBack = RTScalable::getDPI();
|
|
||||||
scaleBack = RTScalable::getScale();
|
|
||||||
}
|
|
||||||
|
|
||||||
void RTSurface::updateImages()
|
|
||||||
{
|
|
||||||
double res = getTweakedDPI();
|
|
||||||
for (auto entry : surfaceCache) {
|
|
||||||
entry.second = loadImage(entry.first, res);
|
|
||||||
//printf("RTSurface::updateImages : %s\n", entry.first.c_str());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void RTSurface::from(Glib::RefPtr<RTSurface> other)
|
double RTSurface::dpiBack = 0.;
|
||||||
{
|
|
||||||
surface = other->surface;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool RTSurface::hasSurface() const
|
int RTSurface::scaleBack = 0;
|
||||||
{
|
|
||||||
return surface ? true : false;
|
|
||||||
}
|
|
||||||
|
|
||||||
Cairo::RefPtr<const Cairo::ImageSurface> RTSurface::get() const
|
|
||||||
{
|
|
||||||
return surface;
|
|
||||||
}
|
|
||||||
|
|
||||||
const Cairo::RefPtr<Cairo::ImageSurface>& RTSurface::get()
|
|
||||||
{
|
|
||||||
return surface;
|
|
||||||
}
|
|
||||||
|
@ -19,28 +19,21 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <gtkmm/image.h>
|
#include <gtkmm/image.h>
|
||||||
|
|
||||||
#include "rtscalable.h"
|
#include "rtscalable.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief A derived class of Gtk::Image in order to handle theme-related icon sets.
|
* @brief A derived class of Gtk::Image in order to handle theme-related icon sets.
|
||||||
*/
|
*/
|
||||||
class RTSurface : public RTScalable
|
class RTSurface :
|
||||||
|
public RTScalable
|
||||||
{
|
{
|
||||||
|
|
||||||
private:
|
|
||||||
|
|
||||||
static double dpiBack; // used to keep track of master dpi change
|
|
||||||
static int scaleBack; // used to keep track of master scale change
|
|
||||||
Cairo::RefPtr<Cairo::ImageSurface> surface;
|
|
||||||
void changeImage (Glib::ustring imageName);
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
RTSurface();
|
||||||
|
RTSurface(const Glib::ustring& fileName, const Glib::ustring& rtlFileName = {});
|
||||||
|
|
||||||
RTSurface ();
|
void setImage(const Glib::ustring& fileName, const Glib::ustring& rtlFileName = {});
|
||||||
RTSurface (const RTSurface& other);
|
|
||||||
RTSurface (Glib::ustring fileName, Glib::ustring rtlFileName = Glib::ustring());
|
|
||||||
|
|
||||||
void setImage (Glib::ustring fileName, Glib::ustring rtlFileName = Glib::ustring());
|
|
||||||
int getWidth() const;
|
int getWidth() const;
|
||||||
int getHeight() const;
|
int getHeight() const;
|
||||||
bool hasSurface() const;
|
bool hasSurface() const;
|
||||||
@ -49,9 +42,13 @@ public:
|
|||||||
const Cairo::RefPtr<Cairo::ImageSurface>& get();
|
const Cairo::RefPtr<Cairo::ImageSurface>& get();
|
||||||
|
|
||||||
static void init();
|
static void init();
|
||||||
static void updateImages ();
|
static void updateImages();
|
||||||
static void setDPInScale (const double newDPI, const int newScale);
|
static void setDPInScale(double newDPI, int newScale);
|
||||||
static void setScale (const int newScale);
|
|
||||||
|
|
||||||
void from(Glib::RefPtr<RTSurface> other);
|
private:
|
||||||
|
void changeImage(const Glib::ustring& imageName);
|
||||||
|
|
||||||
|
static double dpiBack; // used to keep track of master dpi change
|
||||||
|
static int scaleBack; // used to keep track of master scale change
|
||||||
|
Cairo::RefPtr<Cairo::ImageSurface> surface;
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user