Fix high dpi scaling of avatars
This commit is contained in:
parent
11bffd5d90
commit
9efa001bcf
@ -145,13 +145,15 @@ UserMentionsWidget {
|
|||||||
qproperty-highlightedTimestampColor: #e7e7e9;
|
qproperty-highlightedTimestampColor: #e7e7e9;
|
||||||
qproperty-hoverTimestampColor: #f4f5f8;
|
qproperty-hoverTimestampColor: #f4f5f8;
|
||||||
|
|
||||||
qproperty-avatarBgColor: #202228;
|
|
||||||
qproperty-avatarFgColor: white;
|
|
||||||
|
|
||||||
qproperty-bubbleFgColor: white;
|
qproperty-bubbleFgColor: white;
|
||||||
qproperty-bubbleBgColor: #4d84c7;
|
qproperty-bubbleBgColor: #4d84c7;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RoomInfoListItem > Avatar {
|
||||||
|
qproperty-backgroundColor: #202228;
|
||||||
|
qproperty-textColor: white;
|
||||||
|
}
|
||||||
|
|
||||||
CommunitiesListItem {
|
CommunitiesListItem {
|
||||||
qproperty-highlightedBackgroundColor: #4d84c7;
|
qproperty-highlightedBackgroundColor: #4d84c7;
|
||||||
qproperty-hoverBackgroundColor: rgba(230, 230, 230, 30);
|
qproperty-hoverBackgroundColor: rgba(230, 230, 230, 30);
|
||||||
|
@ -111,13 +111,15 @@ RoomInfoListItem {
|
|||||||
qproperty-highlightedTimestampColor: #f4f4f5;
|
qproperty-highlightedTimestampColor: #f4f4f5;
|
||||||
qproperty-hoverTimestampColor: white;
|
qproperty-hoverTimestampColor: white;
|
||||||
|
|
||||||
qproperty-avatarBgColor: #eee;
|
|
||||||
qproperty-avatarFgColor: black;
|
|
||||||
|
|
||||||
qproperty-bubbleFgColor: white;
|
qproperty-bubbleFgColor: white;
|
||||||
qproperty-bubbleBgColor: #38A3D8;
|
qproperty-bubbleBgColor: #38A3D8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RoomInfoListItem > Avatar {
|
||||||
|
qproperty-backgroundColor: #eee;
|
||||||
|
qproperty-textColor: black;
|
||||||
|
}
|
||||||
|
|
||||||
CommunitiesListItem {
|
CommunitiesListItem {
|
||||||
qproperty-highlightedBackgroundColor: #38A3D8;
|
qproperty-highlightedBackgroundColor: #38A3D8;
|
||||||
qproperty-hoverBackgroundColor: rgba(200, 200, 200, 40);
|
qproperty-hoverBackgroundColor: rgba(200, 200, 200, 40);
|
||||||
|
@ -108,13 +108,16 @@ UserMentionsWidget {
|
|||||||
qproperty-highlightedTimestampColor: palette(highlightedtext);
|
qproperty-highlightedTimestampColor: palette(highlightedtext);
|
||||||
qproperty-hoverTimestampColor: palette(highlightedtext);
|
qproperty-hoverTimestampColor: palette(highlightedtext);
|
||||||
|
|
||||||
qproperty-avatarBgColor: palette(base);
|
|
||||||
qproperty-avatarFgColor: palette(text);
|
|
||||||
|
|
||||||
qproperty-bubbleBgColor: palette(base);
|
qproperty-bubbleBgColor: palette(base);
|
||||||
qproperty-bubbleFgColor: palette(text);
|
qproperty-bubbleFgColor: palette(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RoomInfoListItem > Avatar {
|
||||||
|
qproperty-backgroundColor: palette(base);
|
||||||
|
qproperty-textColor: palette(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
CommunitiesListItem {
|
CommunitiesListItem {
|
||||||
qproperty-highlightedBackgroundColor: palette(highlight);
|
qproperty-highlightedBackgroundColor: palette(highlight);
|
||||||
qproperty-hoverBackgroundColor: palette(light);
|
qproperty-hoverBackgroundColor: palette(light);
|
||||||
|
@ -33,8 +33,7 @@
|
|||||||
|
|
||||||
constexpr int MaxUnreadCountDisplayed = 99;
|
constexpr int MaxUnreadCountDisplayed = 99;
|
||||||
|
|
||||||
constexpr int IconSize = 44;
|
constexpr int IconSize = 48;
|
||||||
// constexpr int MaxHeight = IconSize + 2 * Padding;
|
|
||||||
|
|
||||||
struct WidgetMetrics
|
struct WidgetMetrics
|
||||||
{
|
{
|
||||||
@ -77,7 +76,8 @@ RoomInfoListItem::init(QWidget *parent)
|
|||||||
setMouseTracking(true);
|
setMouseTracking(true);
|
||||||
setAttribute(Qt::WA_Hover);
|
setAttribute(Qt::WA_Hover);
|
||||||
|
|
||||||
setFixedHeight(getMetrics(QFont{}).maxHeight);
|
auto wm = getMetrics(QFont{});
|
||||||
|
setFixedHeight(wm.maxHeight);
|
||||||
|
|
||||||
QPainterPath path;
|
QPainterPath path;
|
||||||
path.addRect(0, 0, parent->width(), height());
|
path.addRect(0, 0, parent->width(), height());
|
||||||
@ -86,6 +86,10 @@ RoomInfoListItem::init(QWidget *parent)
|
|||||||
ripple_overlay_->setClipPath(path);
|
ripple_overlay_->setClipPath(path);
|
||||||
ripple_overlay_->setClipping(true);
|
ripple_overlay_->setClipping(true);
|
||||||
|
|
||||||
|
avatar_ = new Avatar(this, wm.iconSize);
|
||||||
|
avatar_->setLetter(utils::firstChar(roomName_));
|
||||||
|
avatar_->move(wm.padding, wm.padding);
|
||||||
|
|
||||||
unreadCountFont_.setPointSizeF(unreadCountFont_.pointSizeF() * 0.8);
|
unreadCountFont_.setPointSizeF(unreadCountFont_.pointSizeF() * 0.8);
|
||||||
unreadCountFont_.setBold(true);
|
unreadCountFont_.setBold(true);
|
||||||
|
|
||||||
@ -130,8 +134,6 @@ RoomInfoListItem::resizeEvent(QResizeEvent *)
|
|||||||
void
|
void
|
||||||
RoomInfoListItem::paintEvent(QPaintEvent *event)
|
RoomInfoListItem::paintEvent(QPaintEvent *event)
|
||||||
{
|
{
|
||||||
bool rounded = QSettings().value("user/avatar_circles", true).toBool();
|
|
||||||
|
|
||||||
Q_UNUSED(event);
|
Q_UNUSED(event);
|
||||||
|
|
||||||
QPainter p(this);
|
QPainter p(this);
|
||||||
@ -160,8 +162,6 @@ RoomInfoListItem::paintEvent(QPaintEvent *event)
|
|||||||
subtitlePen.setColor(subtitleColor_);
|
subtitlePen.setColor(subtitleColor_);
|
||||||
}
|
}
|
||||||
|
|
||||||
QRect avatarRegion(wm.padding, wm.padding, wm.iconSize, wm.iconSize);
|
|
||||||
|
|
||||||
// Description line with the default font.
|
// Description line with the default font.
|
||||||
int bottom_y = wm.maxHeight - wm.padding - metrics.ascent() / 2;
|
int bottom_y = wm.maxHeight - wm.padding - metrics.ascent() / 2;
|
||||||
|
|
||||||
@ -252,38 +252,6 @@ RoomInfoListItem::paintEvent(QPaintEvent *event)
|
|||||||
|
|
||||||
p.setPen(Qt::NoPen);
|
p.setPen(Qt::NoPen);
|
||||||
|
|
||||||
// We using the first letter of room's name.
|
|
||||||
if (roomAvatar_.isNull()) {
|
|
||||||
QBrush brush;
|
|
||||||
brush.setStyle(Qt::SolidPattern);
|
|
||||||
brush.setColor(avatarBgColor());
|
|
||||||
|
|
||||||
p.setPen(Qt::NoPen);
|
|
||||||
p.setBrush(brush);
|
|
||||||
|
|
||||||
rounded ? p.drawEllipse(avatarRegion.center(), wm.iconSize / 2, wm.iconSize / 2)
|
|
||||||
: p.drawRoundedRect(avatarRegion, 3, 3);
|
|
||||||
|
|
||||||
QFont bubbleFont;
|
|
||||||
bubbleFont.setPointSizeF(bubbleFont.pointSizeF() * 1.4);
|
|
||||||
p.setFont(bubbleFont);
|
|
||||||
p.setPen(avatarFgColor());
|
|
||||||
p.setBrush(Qt::NoBrush);
|
|
||||||
p.drawText(
|
|
||||||
avatarRegion.translated(0, -1), Qt::AlignCenter, utils::firstChar(roomName()));
|
|
||||||
} else {
|
|
||||||
p.save();
|
|
||||||
|
|
||||||
QPainterPath path;
|
|
||||||
rounded ? path.addEllipse(wm.padding, wm.padding, wm.iconSize, wm.iconSize)
|
|
||||||
: path.addRoundedRect(avatarRegion, 3, 3);
|
|
||||||
|
|
||||||
p.setClipPath(path);
|
|
||||||
|
|
||||||
p.drawPixmap(avatarRegion, roomAvatar_);
|
|
||||||
p.restore();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (unreadMsgCount_ > 0) {
|
if (unreadMsgCount_ > 0) {
|
||||||
QBrush brush;
|
QBrush brush;
|
||||||
brush.setStyle(Qt::SolidPattern);
|
brush.setStyle(Qt::SolidPattern);
|
||||||
@ -413,10 +381,7 @@ RoomInfoListItem::mousePressEvent(QMouseEvent *event)
|
|||||||
void
|
void
|
||||||
RoomInfoListItem::setAvatar(const QString &avatar_url)
|
RoomInfoListItem::setAvatar(const QString &avatar_url)
|
||||||
{
|
{
|
||||||
AvatarProvider::resolve(avatar_url, IconSize, this, [this](const QPixmap &img) {
|
avatar_->setImage(avatar_url);
|
||||||
roomAvatar_ = img;
|
|
||||||
update();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#include <mtx/responses.hpp>
|
#include <mtx/responses.hpp>
|
||||||
|
|
||||||
#include "CacheStructs.h"
|
#include "CacheStructs.h"
|
||||||
|
#include "ui/Avatar.h"
|
||||||
|
|
||||||
class Menu;
|
class Menu;
|
||||||
class RippleOverlay;
|
class RippleOverlay;
|
||||||
@ -38,9 +39,6 @@ class RoomInfoListItem : public QWidget
|
|||||||
QColor hoverBackgroundColor READ hoverBackgroundColor WRITE setHoverBackgroundColor)
|
QColor hoverBackgroundColor READ hoverBackgroundColor WRITE setHoverBackgroundColor)
|
||||||
Q_PROPERTY(QColor backgroundColor READ backgroundColor WRITE setBackgroundColor)
|
Q_PROPERTY(QColor backgroundColor READ backgroundColor WRITE setBackgroundColor)
|
||||||
|
|
||||||
Q_PROPERTY(QColor avatarBgColor READ avatarBgColor WRITE setAvatarBgColor)
|
|
||||||
Q_PROPERTY(QColor avatarFgColor READ avatarFgColor WRITE setAvatarFgColor)
|
|
||||||
|
|
||||||
Q_PROPERTY(QColor bubbleBgColor READ bubbleBgColor WRITE setBubbleBgColor)
|
Q_PROPERTY(QColor bubbleBgColor READ bubbleBgColor WRITE setBubbleBgColor)
|
||||||
Q_PROPERTY(QColor bubbleFgColor READ bubbleFgColor WRITE setBubbleFgColor)
|
Q_PROPERTY(QColor bubbleFgColor READ bubbleFgColor WRITE setBubbleFgColor)
|
||||||
|
|
||||||
@ -84,8 +82,6 @@ public:
|
|||||||
QColor hoverSubtitleColor() const { return hoverSubtitleColor_; }
|
QColor hoverSubtitleColor() const { return hoverSubtitleColor_; }
|
||||||
QColor hoverTimestampColor() const { return hoverTimestampColor_; }
|
QColor hoverTimestampColor() const { return hoverTimestampColor_; }
|
||||||
QColor backgroundColor() const { return backgroundColor_; }
|
QColor backgroundColor() const { return backgroundColor_; }
|
||||||
QColor avatarBgColor() const { return avatarBgColor_; }
|
|
||||||
QColor avatarFgColor() const { return avatarFgColor_; }
|
|
||||||
|
|
||||||
QColor highlightedTitleColor() const { return highlightedTitleColor_; }
|
QColor highlightedTitleColor() const { return highlightedTitleColor_; }
|
||||||
QColor highlightedSubtitleColor() const { return highlightedSubtitleColor_; }
|
QColor highlightedSubtitleColor() const { return highlightedSubtitleColor_; }
|
||||||
@ -108,8 +104,6 @@ public:
|
|||||||
void setHoverTimestampColor(QColor &color) { hoverTimestampColor_ = color; }
|
void setHoverTimestampColor(QColor &color) { hoverTimestampColor_ = color; }
|
||||||
void setBackgroundColor(QColor &color) { backgroundColor_ = color; }
|
void setBackgroundColor(QColor &color) { backgroundColor_ = color; }
|
||||||
void setTimestampColor(QColor &color) { timestampColor_ = color; }
|
void setTimestampColor(QColor &color) { timestampColor_ = color; }
|
||||||
void setAvatarFgColor(QColor &color) { avatarFgColor_ = color; }
|
|
||||||
void setAvatarBgColor(QColor &color) { avatarBgColor_ = color; }
|
|
||||||
|
|
||||||
void setHighlightedTitleColor(QColor &color) { highlightedTitleColor_ = color; }
|
void setHighlightedTitleColor(QColor &color) { highlightedTitleColor_ = color; }
|
||||||
void setHighlightedSubtitleColor(QColor &color) { highlightedSubtitleColor_ = color; }
|
void setHighlightedSubtitleColor(QColor &color) { highlightedSubtitleColor_ = color; }
|
||||||
@ -163,6 +157,7 @@ private:
|
|||||||
QString roomName() { return roomName_; }
|
QString roomName() { return roomName_; }
|
||||||
|
|
||||||
RippleOverlay *ripple_overlay_;
|
RippleOverlay *ripple_overlay_;
|
||||||
|
Avatar *avatar_;
|
||||||
|
|
||||||
enum class RoomType
|
enum class RoomType
|
||||||
{
|
{
|
||||||
@ -180,8 +175,6 @@ private:
|
|||||||
|
|
||||||
DescInfo lastMsgInfo_;
|
DescInfo lastMsgInfo_;
|
||||||
|
|
||||||
QPixmap roomAvatar_;
|
|
||||||
|
|
||||||
Menu *menu_;
|
Menu *menu_;
|
||||||
QAction *leaveRoom_;
|
QAction *leaveRoom_;
|
||||||
|
|
||||||
@ -219,9 +212,6 @@ private:
|
|||||||
QColor highlightedTimestampColor_;
|
QColor highlightedTimestampColor_;
|
||||||
QColor hoverTimestampColor_;
|
QColor hoverTimestampColor_;
|
||||||
|
|
||||||
QColor avatarBgColor_;
|
|
||||||
QColor avatarFgColor_;
|
|
||||||
|
|
||||||
QColor bubbleBgColor_;
|
QColor bubbleBgColor_;
|
||||||
QColor bubbleFgColor_;
|
QColor bubbleFgColor_;
|
||||||
};
|
};
|
||||||
|
@ -73,21 +73,31 @@ Avatar::setLetter(const QString &letter)
|
|||||||
void
|
void
|
||||||
Avatar::setImage(const QString &avatar_url)
|
Avatar::setImage(const QString &avatar_url)
|
||||||
{
|
{
|
||||||
AvatarProvider::resolve(avatar_url, size_, this, [this](QPixmap pm) {
|
avatar_url_ = avatar_url;
|
||||||
type_ = ui::AvatarType::Image;
|
AvatarProvider::resolve(avatar_url,
|
||||||
pixmap_ = pm;
|
static_cast<int>(size_ * pixmap_.devicePixelRatio()),
|
||||||
update();
|
this,
|
||||||
});
|
[this](QPixmap pm) {
|
||||||
|
type_ = ui::AvatarType::Image;
|
||||||
|
pixmap_ = pm;
|
||||||
|
update();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
Avatar::setImage(const QString &room, const QString &user)
|
Avatar::setImage(const QString &room, const QString &user)
|
||||||
{
|
{
|
||||||
AvatarProvider::resolve(room, user, size_, this, [this](QPixmap pm) {
|
room_ = room;
|
||||||
type_ = ui::AvatarType::Image;
|
user_ = user;
|
||||||
pixmap_ = pm;
|
AvatarProvider::resolve(room,
|
||||||
update();
|
user,
|
||||||
});
|
static_cast<int>(size_ * pixmap_.devicePixelRatio()),
|
||||||
|
this,
|
||||||
|
[this](QPixmap pm) {
|
||||||
|
type_ = ui::AvatarType::Image;
|
||||||
|
pixmap_ = pm;
|
||||||
|
update();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -118,6 +128,16 @@ Avatar::paintEvent(QPaintEvent *)
|
|||||||
painter.setBrush(brush);
|
painter.setBrush(brush);
|
||||||
rounded ? painter.drawEllipse(r.center(), hs, hs)
|
rounded ? painter.drawEllipse(r.center(), hs, hs)
|
||||||
: painter.drawRoundedRect(r, 3, 3);
|
: painter.drawRoundedRect(r, 3, 3);
|
||||||
|
} else if (painter.isActive() &&
|
||||||
|
abs(pixmap_.devicePixelRatio() - painter.device()->devicePixelRatioF()) > 0.01) {
|
||||||
|
pixmap_ =
|
||||||
|
pixmap_.scaled(QSize(size_, size_) * painter.device()->devicePixelRatioF());
|
||||||
|
pixmap_.setDevicePixelRatio(painter.device()->devicePixelRatioF());
|
||||||
|
|
||||||
|
if (!avatar_url_.isEmpty())
|
||||||
|
setImage(avatar_url_);
|
||||||
|
else
|
||||||
|
setImage(room_, user_);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (type_) {
|
switch (type_) {
|
||||||
|
@ -38,6 +38,7 @@ private:
|
|||||||
|
|
||||||
ui::AvatarType type_;
|
ui::AvatarType type_;
|
||||||
QString letter_;
|
QString letter_;
|
||||||
|
QString avatar_url_, room_, user_;
|
||||||
QColor background_color_;
|
QColor background_color_;
|
||||||
QColor text_color_;
|
QColor text_color_;
|
||||||
QIcon icon_;
|
QIcon icon_;
|
||||||
|
Loading…
Reference in New Issue
Block a user