mirror of https://github.com/procxx/kepka.git
Use objects instead of pointers for corners.
Also don't change mask corner images when color theme is changed. This prevents race condition in mask corner images access, because the GIF frame readers access mask corner images from other threads.
This commit is contained in:
parent
9fd8b040b7
commit
2f816942b8
|
@ -111,15 +111,12 @@ namespace {
|
||||||
style::font monofont;
|
style::font monofont;
|
||||||
|
|
||||||
struct CornersPixmaps {
|
struct CornersPixmaps {
|
||||||
CornersPixmaps() {
|
QPixmap p[4];
|
||||||
memset(p, 0, sizeof(p));
|
|
||||||
}
|
|
||||||
QPixmap *p[4];
|
|
||||||
};
|
};
|
||||||
CornersPixmaps corners[RoundCornersCount];
|
QVector<CornersPixmaps> corners;
|
||||||
using CornersMap = QMap<uint32, CornersPixmaps>;
|
using CornersMap = QMap<uint32, CornersPixmaps>;
|
||||||
CornersMap cornersMap;
|
CornersMap cornersMap;
|
||||||
QImage *cornersMaskLarge[4] = { nullptr }, *cornersMaskSmall[4] = { nullptr };
|
QImage cornersMaskLarge[4], cornersMaskSmall[4];
|
||||||
|
|
||||||
using EmojiImagesMap = QMap<int, QPixmap>;
|
using EmojiImagesMap = QMap<int, QPixmap>;
|
||||||
EmojiImagesMap MainEmojiMap;
|
EmojiImagesMap MainEmojiMap;
|
||||||
|
@ -2174,6 +2171,7 @@ namespace {
|
||||||
}
|
}
|
||||||
|
|
||||||
void prepareCorners(RoundCorners index, int32 radius, const QBrush &brush, const style::color *shadow = nullptr, QImage *cors = nullptr) {
|
void prepareCorners(RoundCorners index, int32 radius, const QBrush &brush, const style::color *shadow = nullptr, QImage *cors = nullptr) {
|
||||||
|
Expects(::corners.size() > index);
|
||||||
int32 r = radius * cIntRetinaFactor(), s = st::msgShadow * cIntRetinaFactor();
|
int32 r = radius * cIntRetinaFactor(), s = st::msgShadow * cIntRetinaFactor();
|
||||||
QImage rect(r * 3, r * 3 + (shadow ? s : 0), QImage::Format_ARGB32_Premultiplied), localCors[4];
|
QImage rect(r * 3, r * 3 + (shadow ? s : 0), QImage::Format_ARGB32_Premultiplied), localCors[4];
|
||||||
{
|
{
|
||||||
|
@ -2198,8 +2196,8 @@ namespace {
|
||||||
cors[3] = rect.copy(r * 2, r * 2, r, r + (shadow ? s : 0));
|
cors[3] = rect.copy(r * 2, r * 2, r, r + (shadow ? s : 0));
|
||||||
if (index != SmallMaskCorners && index != LargeMaskCorners) {
|
if (index != SmallMaskCorners && index != LargeMaskCorners) {
|
||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
::corners[index].p[i] = new QPixmap(pixmapFromImageInPlace(std::move(cors[i])));
|
::corners[index].p[i] = pixmapFromImageInPlace(std::move(cors[i]));
|
||||||
::corners[index].p[i]->setDevicePixelRatio(cRetinaFactor());
|
::corners[index].p[i].setDevicePixelRatio(cRetinaFactor());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2221,18 +2219,21 @@ namespace {
|
||||||
return MsgRadius;
|
return MsgRadius;
|
||||||
}
|
}
|
||||||
|
|
||||||
void createCorners() {
|
void createMaskCorners() {
|
||||||
QImage mask[4];
|
QImage mask[4];
|
||||||
prepareCorners(LargeMaskCorners, msgRadius(), QColor(255, 255, 255), nullptr, mask);
|
|
||||||
for (int i = 0; i < 4; ++i) {
|
|
||||||
::cornersMaskLarge[i] = new QImage(mask[i].convertToFormat(QImage::Format_ARGB32_Premultiplied));
|
|
||||||
::cornersMaskLarge[i]->setDevicePixelRatio(cRetinaFactor());
|
|
||||||
}
|
|
||||||
prepareCorners(SmallMaskCorners, st::buttonRadius, QColor(255, 255, 255), nullptr, mask);
|
prepareCorners(SmallMaskCorners, st::buttonRadius, QColor(255, 255, 255), nullptr, mask);
|
||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
::cornersMaskSmall[i] = new QImage(mask[i].convertToFormat(QImage::Format_ARGB32_Premultiplied));
|
::cornersMaskSmall[i] = mask[i].convertToFormat(QImage::Format_ARGB32_Premultiplied);
|
||||||
::cornersMaskSmall[i]->setDevicePixelRatio(cRetinaFactor());
|
::cornersMaskSmall[i].setDevicePixelRatio(cRetinaFactor());
|
||||||
}
|
}
|
||||||
|
prepareCorners(LargeMaskCorners, msgRadius(), QColor(255, 255, 255), nullptr, mask);
|
||||||
|
for (int i = 0; i < 4; ++i) {
|
||||||
|
::cornersMaskLarge[i] = mask[i].convertToFormat(QImage::Format_ARGB32_Premultiplied);
|
||||||
|
::cornersMaskLarge[i].setDevicePixelRatio(cRetinaFactor());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void createPaletteCorners() {
|
||||||
prepareCorners(MenuCorners, st::buttonRadius, st::menuBg);
|
prepareCorners(MenuCorners, st::buttonRadius, st::menuBg);
|
||||||
prepareCorners(BoxCorners, st::boxRadius, st::boxBg);
|
prepareCorners(BoxCorners, st::boxRadius, st::boxBg);
|
||||||
prepareCorners(BotKbOverCorners, st::dateRadius, st::msgBotKbOverBgAdd);
|
prepareCorners(BotKbOverCorners, st::dateRadius, st::msgBotKbOverBgAdd);
|
||||||
|
@ -2262,19 +2263,14 @@ namespace {
|
||||||
prepareCorners(MessageOutSelectedCorners, msgRadius(), st::msgOutBgSelected, &st::msgOutShadowSelected);
|
prepareCorners(MessageOutSelectedCorners, msgRadius(), st::msgOutBgSelected, &st::msgOutShadowSelected);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void createCorners() {
|
||||||
|
::corners.resize(RoundCornersCount);
|
||||||
|
createMaskCorners();
|
||||||
|
createPaletteCorners();
|
||||||
|
}
|
||||||
|
|
||||||
void clearCorners() {
|
void clearCorners() {
|
||||||
for (int j = 0; j < 4; ++j) {
|
::corners.clear();
|
||||||
for (int i = 0; i < RoundCornersCount; ++i) {
|
|
||||||
delete ::corners[i].p[j]; ::corners[i].p[j] = nullptr;
|
|
||||||
}
|
|
||||||
delete ::cornersMaskSmall[j]; ::cornersMaskSmall[j] = nullptr;
|
|
||||||
delete ::cornersMaskLarge[j]; ::cornersMaskLarge[j] = nullptr;
|
|
||||||
}
|
|
||||||
for (auto i = ::cornersMap.cbegin(), e = ::cornersMap.cend(); i != e; ++i) {
|
|
||||||
for (int j = 0; j < 4; ++j) {
|
|
||||||
delete i->p[j];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
::cornersMap.clear();
|
::cornersMap.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2303,18 +2299,13 @@ namespace {
|
||||||
using Update = Window::Theme::BackgroundUpdate;
|
using Update = Window::Theme::BackgroundUpdate;
|
||||||
static auto subscription = Window::Theme::Background()->add_subscription([](const Update &update) {
|
static auto subscription = Window::Theme::Background()->add_subscription([](const Update &update) {
|
||||||
if (update.paletteChanged()) {
|
if (update.paletteChanged()) {
|
||||||
clearCorners();
|
createPaletteCorners();
|
||||||
createCorners();
|
|
||||||
|
|
||||||
if (App::main()) {
|
if (App::main()) {
|
||||||
App::main()->updateScrollColors();
|
App::main()->updateScrollColors();
|
||||||
}
|
}
|
||||||
HistoryLayout::serviceColorsUpdated();
|
HistoryLayout::serviceColorsUpdated();
|
||||||
} else if (update.type == Update::Type::New) {
|
} else if (update.type == Update::Type::New) {
|
||||||
for (int i = 0; i < 4; ++i) {
|
|
||||||
delete ::corners[StickerCorners].p[i]; ::corners[StickerCorners].p[i] = nullptr;
|
|
||||||
delete ::corners[StickerSelectedCorners].p[i]; ::corners[StickerSelectedCorners].p[i] = nullptr;
|
|
||||||
}
|
|
||||||
prepareCorners(StickerCorners, st::dateRadius, st::msgServiceBg);
|
prepareCorners(StickerCorners, st::dateRadius, st::msgServiceBg);
|
||||||
prepareCorners(StickerSelectedCorners, st::dateRadius, st::msgServiceBgSelected);
|
prepareCorners(StickerSelectedCorners, st::dateRadius, st::msgServiceBgSelected);
|
||||||
|
|
||||||
|
@ -2778,7 +2769,7 @@ namespace {
|
||||||
roundRect(p, rect, st::msgInBg, MessageInCorners, nullptr, parts);
|
roundRect(p, rect, st::msgInBg, MessageInCorners, nullptr, parts);
|
||||||
}
|
}
|
||||||
|
|
||||||
QImage **cornersMask(ImageRoundRadius radius) {
|
QImage *cornersMask(ImageRoundRadius radius) {
|
||||||
switch (radius) {
|
switch (radius) {
|
||||||
case ImageRoundRadius::Large: return ::cornersMaskLarge;
|
case ImageRoundRadius::Large: return ::cornersMaskLarge;
|
||||||
case ImageRoundRadius::Small:
|
case ImageRoundRadius::Small:
|
||||||
|
@ -2788,8 +2779,8 @@ namespace {
|
||||||
}
|
}
|
||||||
|
|
||||||
void roundRect(Painter &p, int32 x, int32 y, int32 w, int32 h, style::color bg, const CornersPixmaps &corner, const style::color *shadow, RectParts parts) {
|
void roundRect(Painter &p, int32 x, int32 y, int32 w, int32 h, style::color bg, const CornersPixmaps &corner, const style::color *shadow, RectParts parts) {
|
||||||
auto cornerWidth = corner.p[0]->width() / cIntRetinaFactor();
|
auto cornerWidth = corner.p[0].width() / cIntRetinaFactor();
|
||||||
auto cornerHeight = corner.p[0]->height() / cIntRetinaFactor();
|
auto cornerHeight = corner.p[0].height() / cIntRetinaFactor();
|
||||||
if (w < 2 * cornerWidth || h < 2 * cornerHeight) return;
|
if (w < 2 * cornerWidth || h < 2 * cornerHeight) return;
|
||||||
if (w > 2 * cornerWidth) {
|
if (w > 2 * cornerWidth) {
|
||||||
if (parts & RectPart::Top) {
|
if (parts & RectPart::Top) {
|
||||||
|
@ -2818,16 +2809,16 @@ namespace {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (parts & RectPart::TopLeft) {
|
if (parts & RectPart::TopLeft) {
|
||||||
p.drawPixmap(x, y, *corner.p[0]);
|
p.drawPixmap(x, y, corner.p[0]);
|
||||||
}
|
}
|
||||||
if (parts & RectPart::TopRight) {
|
if (parts & RectPart::TopRight) {
|
||||||
p.drawPixmap(x + w - cornerWidth, y, *corner.p[1]);
|
p.drawPixmap(x + w - cornerWidth, y, corner.p[1]);
|
||||||
}
|
}
|
||||||
if (parts & RectPart::BottomLeft) {
|
if (parts & RectPart::BottomLeft) {
|
||||||
p.drawPixmap(x, y + h - cornerHeight, *corner.p[2]);
|
p.drawPixmap(x, y + h - cornerHeight, corner.p[2]);
|
||||||
}
|
}
|
||||||
if (parts & RectPart::BottomRight) {
|
if (parts & RectPart::BottomRight) {
|
||||||
p.drawPixmap(x + w - cornerWidth, y + h - cornerHeight, *corner.p[3]);
|
p.drawPixmap(x + w - cornerWidth, y + h - cornerHeight, corner.p[3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2837,18 +2828,18 @@ namespace {
|
||||||
|
|
||||||
void roundShadow(Painter &p, int32 x, int32 y, int32 w, int32 h, style::color shadow, RoundCorners index, RectParts parts) {
|
void roundShadow(Painter &p, int32 x, int32 y, int32 w, int32 h, style::color shadow, RoundCorners index, RectParts parts) {
|
||||||
auto &corner = ::corners[index];
|
auto &corner = ::corners[index];
|
||||||
auto cornerWidth = corner.p[0]->width() / cIntRetinaFactor();
|
auto cornerWidth = corner.p[0].width() / cIntRetinaFactor();
|
||||||
auto cornerHeight = corner.p[0]->height() / cIntRetinaFactor();
|
auto cornerHeight = corner.p[0].height() / cIntRetinaFactor();
|
||||||
if (parts & RectPart::Bottom) {
|
if (parts & RectPart::Bottom) {
|
||||||
p.fillRect(x + cornerWidth, y + h, w - 2 * cornerWidth, st::msgShadow, shadow);
|
p.fillRect(x + cornerWidth, y + h, w - 2 * cornerWidth, st::msgShadow, shadow);
|
||||||
}
|
}
|
||||||
if (parts & RectPart::BottomLeft) {
|
if (parts & RectPart::BottomLeft) {
|
||||||
p.fillRect(x, y + h - cornerHeight, cornerWidth, st::msgShadow, shadow);
|
p.fillRect(x, y + h - cornerHeight, cornerWidth, st::msgShadow, shadow);
|
||||||
p.drawPixmap(x, y + h - cornerHeight + st::msgShadow, *corner.p[2]);
|
p.drawPixmap(x, y + h - cornerHeight + st::msgShadow, corner.p[2]);
|
||||||
}
|
}
|
||||||
if (parts & RectPart::BottomRight) {
|
if (parts & RectPart::BottomRight) {
|
||||||
p.fillRect(x + w - cornerWidth, y + h - cornerHeight, cornerWidth, st::msgShadow, shadow);
|
p.fillRect(x + w - cornerWidth, y + h - cornerHeight, cornerWidth, st::msgShadow, shadow);
|
||||||
p.drawPixmap(x + w - cornerWidth, y + h - cornerHeight + st::msgShadow, *corner.p[3]);
|
p.drawPixmap(x + w - cornerWidth, y + h - cornerHeight + st::msgShadow, corner.p[3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2865,8 +2856,8 @@ namespace {
|
||||||
|
|
||||||
CornersPixmaps pixmaps;
|
CornersPixmaps pixmaps;
|
||||||
for (int j = 0; j < 4; ++j) {
|
for (int j = 0; j < 4; ++j) {
|
||||||
pixmaps.p[j] = new QPixmap(pixmapFromImageInPlace(std::move(images[j])));
|
pixmaps.p[j] = pixmapFromImageInPlace(std::move(images[j]));
|
||||||
pixmaps.p[j]->setDevicePixelRatio(cRetinaFactor());
|
pixmaps.p[j].setDevicePixelRatio(cRetinaFactor());
|
||||||
}
|
}
|
||||||
i = cornersMap.insert(colorKey, pixmaps);
|
i = cornersMap.insert(colorKey, pixmaps);
|
||||||
}
|
}
|
||||||
|
|
|
@ -283,7 +283,7 @@ namespace App {
|
||||||
void complexOverlayRect(Painter &p, QRect rect, ImageRoundRadius radius, ImageRoundCorners corners);
|
void complexOverlayRect(Painter &p, QRect rect, ImageRoundRadius radius, ImageRoundCorners corners);
|
||||||
void complexLocationRect(Painter &p, QRect rect, ImageRoundRadius radius, ImageRoundCorners corners);
|
void complexLocationRect(Painter &p, QRect rect, ImageRoundRadius radius, ImageRoundCorners corners);
|
||||||
|
|
||||||
QImage **cornersMask(ImageRoundRadius radius);
|
QImage *cornersMask(ImageRoundRadius radius);
|
||||||
void roundRect(Painter &p, int32 x, int32 y, int32 w, int32 h, style::color bg, RoundCorners index, const style::color *shadow = nullptr, RectParts parts = RectPart::Full);
|
void roundRect(Painter &p, int32 x, int32 y, int32 w, int32 h, style::color bg, RoundCorners index, const style::color *shadow = nullptr, RectParts parts = RectPart::Full);
|
||||||
inline void roundRect(Painter &p, const QRect &rect, style::color bg, RoundCorners index, const style::color *shadow = nullptr, RectParts parts = RectPart::Full) {
|
inline void roundRect(Painter &p, const QRect &rect, style::color bg, RoundCorners index, const style::color *shadow = nullptr, RectParts parts = RectPart::Full) {
|
||||||
return roundRect(p, rect.x(), rect.y(), rect.width(), rect.height(), bg, index, shadow, parts);
|
return roundRect(p, rect.x(), rect.y(), rect.width(), rect.height(), bg, index, shadow, parts);
|
||||||
|
|
|
@ -265,7 +265,7 @@ void TabbedPanel::startShowAnimation() {
|
||||||
auto inner = rect().marginsRemoved(st::emojiPanMargins);
|
auto inner = rect().marginsRemoved(st::emojiPanMargins);
|
||||||
_showAnimation->setFinalImage(std::move(image), QRect(inner.topLeft() * cIntRetinaFactor(), inner.size() * cIntRetinaFactor()));
|
_showAnimation->setFinalImage(std::move(image), QRect(inner.topLeft() * cIntRetinaFactor(), inner.size() * cIntRetinaFactor()));
|
||||||
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
||||||
_showAnimation->setCornerMasks(QImage(*corners[0]), QImage(*corners[1]), QImage(*corners[2]), QImage(*corners[3]));
|
_showAnimation->setCornerMasks(corners[0], corners[1], corners[2], corners[3]);
|
||||||
_showAnimation->start();
|
_showAnimation->start();
|
||||||
}
|
}
|
||||||
hideChildren();
|
hideChildren();
|
||||||
|
|
|
@ -653,7 +653,7 @@ void TabbedSelector::switchTab() {
|
||||||
auto slidingRect = QRect(_tabsSlider->x() * cIntRetinaFactor(), _scroll->y() * cIntRetinaFactor(), _tabsSlider->width() * cIntRetinaFactor(), (height() - _scroll->y()) * cIntRetinaFactor());
|
auto slidingRect = QRect(_tabsSlider->x() * cIntRetinaFactor(), _scroll->y() * cIntRetinaFactor(), _tabsSlider->width() * cIntRetinaFactor(), (height() - _scroll->y()) * cIntRetinaFactor());
|
||||||
_slideAnimation->setFinalImages(direction, std::move(wasCache), std::move(nowCache), slidingRect, wasSectionIcons);
|
_slideAnimation->setFinalImages(direction, std::move(wasCache), std::move(nowCache), slidingRect, wasSectionIcons);
|
||||||
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
||||||
_slideAnimation->setCornerMasks(QImage(*corners[0]), QImage(*corners[1]), QImage(*corners[2]), QImage(*corners[3]));
|
_slideAnimation->setCornerMasks(corners[0], corners[1], corners[2], corners[3]);
|
||||||
_slideAnimation->start();
|
_slideAnimation->start();
|
||||||
|
|
||||||
hideForSliding();
|
hideForSliding();
|
||||||
|
|
|
@ -897,7 +897,7 @@ void Widget::startShowAnimation() {
|
||||||
auto inner = rect().marginsRemoved(st::emojiPanMargins);
|
auto inner = rect().marginsRemoved(st::emojiPanMargins);
|
||||||
_showAnimation->setFinalImage(std::move(image), QRect(inner.topLeft() * cIntRetinaFactor(), inner.size() * cIntRetinaFactor()));
|
_showAnimation->setFinalImage(std::move(image), QRect(inner.topLeft() * cIntRetinaFactor(), inner.size() * cIntRetinaFactor()));
|
||||||
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
||||||
_showAnimation->setCornerMasks(QImage(*corners[0]), QImage(*corners[1]), QImage(*corners[2]), QImage(*corners[3]));
|
_showAnimation->setCornerMasks(corners[0], corners[1], corners[2], corners[3]);
|
||||||
_showAnimation->start();
|
_showAnimation->start();
|
||||||
}
|
}
|
||||||
hideChildren();
|
hideChildren();
|
||||||
|
|
|
@ -65,16 +65,16 @@ void RoundShadowAnimation::setShadow(const style::Shadow &st) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void RoundShadowAnimation::setCornerMasks(QImage &&topLeft, QImage &&topRight, QImage &&bottomLeft, QImage &&bottomRight) {
|
void RoundShadowAnimation::setCornerMasks(const QImage &topLeft, const QImage &topRight, const QImage &bottomLeft, const QImage &bottomRight) {
|
||||||
setCornerMask(_topLeft, std::move(topLeft));
|
setCornerMask(_topLeft, topLeft);
|
||||||
setCornerMask(_topRight, std::move(topRight));
|
setCornerMask(_topRight, topRight);
|
||||||
setCornerMask(_bottomLeft, std::move(bottomLeft));
|
setCornerMask(_bottomLeft, bottomLeft);
|
||||||
setCornerMask(_bottomRight, std::move(bottomRight));
|
setCornerMask(_bottomRight, bottomRight);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RoundShadowAnimation::setCornerMask(Corner &corner, QImage &&image) {
|
void RoundShadowAnimation::setCornerMask(Corner &corner, const QImage &image) {
|
||||||
t_assert(!started());
|
t_assert(!started());
|
||||||
corner.image = std::move(image);
|
corner.image = image;
|
||||||
if (corner.valid()) {
|
if (corner.valid()) {
|
||||||
corner.width = corner.image.width();
|
corner.width = corner.image.width();
|
||||||
corner.height = corner.image.height();
|
corner.height = corner.image.height();
|
||||||
|
|
|
@ -26,7 +26,7 @@ namespace Ui {
|
||||||
|
|
||||||
class RoundShadowAnimation {
|
class RoundShadowAnimation {
|
||||||
public:
|
public:
|
||||||
void setCornerMasks(QImage &&topLeft, QImage &&topRight, QImage &&bottomLeft, QImage &&bottomRight);
|
void setCornerMasks(const QImage &topLeft, const QImage &topRight, const QImage &bottomLeft, const QImage &bottomRight);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void start(int frameWidth, int frameHeight, float64 devicePixelRatio);
|
void start(int frameWidth, int frameHeight, float64 devicePixelRatio);
|
||||||
|
@ -48,7 +48,7 @@ protected:
|
||||||
return !image.isNull();
|
return !image.isNull();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
void setCornerMask(Corner &corner, QImage &&image);
|
void setCornerMask(Corner &corner, const QImage &image);
|
||||||
void paintCorner(Corner &corner, int left, int top);
|
void paintCorner(Corner &corner, int left, int top);
|
||||||
|
|
||||||
struct Shadow {
|
struct Shadow {
|
||||||
|
|
|
@ -204,13 +204,13 @@ void prepareRound(QImage &image, ImageRoundRadius radius, ImageRoundCorners corn
|
||||||
image = std::move(image).convertToFormat(QImage::Format_ARGB32_Premultiplied);
|
image = std::move(image).convertToFormat(QImage::Format_ARGB32_Premultiplied);
|
||||||
t_assert(!image.isNull());
|
t_assert(!image.isNull());
|
||||||
|
|
||||||
QImage **masks = App::cornersMask(radius);
|
auto masks = App::cornersMask(radius);
|
||||||
prepareRound(image, masks, corners);
|
prepareRound(image, masks, corners);
|
||||||
}
|
}
|
||||||
|
|
||||||
void prepareRound(QImage &image, QImage **cornerMasks, ImageRoundCorners corners) {
|
void prepareRound(QImage &image, QImage *cornerMasks, ImageRoundCorners corners) {
|
||||||
auto cornerWidth = cornerMasks[0]->width();
|
auto cornerWidth = cornerMasks[0].width();
|
||||||
auto cornerHeight = cornerMasks[0]->height();
|
auto cornerHeight = cornerMasks[0].height();
|
||||||
auto imageWidth = image.width();
|
auto imageWidth = image.width();
|
||||||
auto imageHeight = image.height();
|
auto imageHeight = image.height();
|
||||||
if (imageWidth < 2 * cornerWidth || imageHeight < 2 * cornerHeight) {
|
if (imageWidth < 2 * cornerWidth || imageHeight < 2 * cornerHeight) {
|
||||||
|
@ -226,15 +226,15 @@ void prepareRound(QImage &image, QImage **cornerMasks, ImageRoundCorners corners
|
||||||
auto intsTopRight = ints + imageWidth - cornerWidth;
|
auto intsTopRight = ints + imageWidth - cornerWidth;
|
||||||
auto intsBottomLeft = ints + (imageHeight - cornerHeight) * imageWidth;
|
auto intsBottomLeft = ints + (imageHeight - cornerHeight) * imageWidth;
|
||||||
auto intsBottomRight = ints + (imageHeight - cornerHeight + 1) * imageWidth - cornerWidth;
|
auto intsBottomRight = ints + (imageHeight - cornerHeight + 1) * imageWidth - cornerWidth;
|
||||||
auto maskCorner = [imageWidth, imageHeight, imageIntsPerPixel, imageIntsPerLine](uint32 *imageInts, const QImage *mask) {
|
auto maskCorner = [imageWidth, imageHeight, imageIntsPerPixel, imageIntsPerLine](uint32 *imageInts, const QImage &mask) {
|
||||||
auto maskWidth = mask->width();
|
auto maskWidth = mask.width();
|
||||||
auto maskHeight = mask->height();
|
auto maskHeight = mask.height();
|
||||||
auto maskBytesPerPixel = (mask->depth() >> 3);
|
auto maskBytesPerPixel = (mask.depth() >> 3);
|
||||||
auto maskBytesPerLine = mask->bytesPerLine();
|
auto maskBytesPerLine = mask.bytesPerLine();
|
||||||
auto maskBytesAdded = maskBytesPerLine - maskWidth * maskBytesPerPixel;
|
auto maskBytesAdded = maskBytesPerLine - maskWidth * maskBytesPerPixel;
|
||||||
auto maskBytes = mask->constBits();
|
auto maskBytes = mask.constBits();
|
||||||
t_assert(maskBytesAdded >= 0);
|
t_assert(maskBytesAdded >= 0);
|
||||||
t_assert(mask->depth() == (maskBytesPerPixel << 3));
|
t_assert(mask.depth() == (maskBytesPerPixel << 3));
|
||||||
auto imageIntsAdded = imageIntsPerLine - maskWidth * imageIntsPerPixel;
|
auto imageIntsAdded = imageIntsPerLine - maskWidth * imageIntsPerPixel;
|
||||||
t_assert(imageIntsAdded >= 0);
|
t_assert(imageIntsAdded >= 0);
|
||||||
for (auto y = 0; y != maskHeight; ++y) {
|
for (auto y = 0; y != maskHeight; ++y) {
|
||||||
|
|
|
@ -180,7 +180,7 @@ namespace Images {
|
||||||
|
|
||||||
QImage prepareBlur(QImage image);
|
QImage prepareBlur(QImage image);
|
||||||
void prepareRound(QImage &image, ImageRoundRadius radius, ImageRoundCorners corners = ImageRoundCorner::All);
|
void prepareRound(QImage &image, ImageRoundRadius radius, ImageRoundCorners corners = ImageRoundCorner::All);
|
||||||
void prepareRound(QImage &image, QImage **cornerMasks, ImageRoundCorners corners = ImageRoundCorner::All);
|
void prepareRound(QImage &image, QImage *cornerMasks, ImageRoundCorners corners = ImageRoundCorner::All);
|
||||||
void prepareCircle(QImage &image);
|
void prepareCircle(QImage &image);
|
||||||
QImage prepareColored(style::color add, QImage image);
|
QImage prepareColored(style::color add, QImage image);
|
||||||
QImage prepareOpaque(QImage image);
|
QImage prepareOpaque(QImage image);
|
||||||
|
|
|
@ -254,7 +254,7 @@ void InnerDropdown::startShowAnimation() {
|
||||||
auto inner = rect().marginsRemoved(_st.padding);
|
auto inner = rect().marginsRemoved(_st.padding);
|
||||||
_showAnimation->setFinalImage(std::move(cache), QRect(inner.topLeft() * cIntRetinaFactor(), inner.size() * cIntRetinaFactor()));
|
_showAnimation->setFinalImage(std::move(cache), QRect(inner.topLeft() * cIntRetinaFactor(), inner.size() * cIntRetinaFactor()));
|
||||||
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
||||||
_showAnimation->setCornerMasks(QImage(*corners[0]), QImage(*corners[1]), QImage(*corners[2]), QImage(*corners[3]));
|
_showAnimation->setCornerMasks(corners[0], corners[1], corners[2], corners[3]);
|
||||||
_showAnimation->start();
|
_showAnimation->start();
|
||||||
}
|
}
|
||||||
hideChildren();
|
hideChildren();
|
||||||
|
|
|
@ -362,7 +362,7 @@ void PopupMenu::startShowAnimation() {
|
||||||
_showAnimation->setFinalImage(std::move(cache), QRect(_inner.topLeft() * cIntRetinaFactor(), _inner.size() * cIntRetinaFactor()));
|
_showAnimation->setFinalImage(std::move(cache), QRect(_inner.topLeft() * cIntRetinaFactor(), _inner.size() * cIntRetinaFactor()));
|
||||||
if (_useTransparency) {
|
if (_useTransparency) {
|
||||||
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
auto corners = App::cornersMask(ImageRoundRadius::Small);
|
||||||
_showAnimation->setCornerMasks(QImage(*corners[0]), QImage(*corners[1]), QImage(*corners[2]), QImage(*corners[3]));
|
_showAnimation->setCornerMasks(corners[0], corners[1], corners[2], corners[3]);
|
||||||
} else {
|
} else {
|
||||||
_showAnimation->setSkipShadow(true);
|
_showAnimation->setSkipShadow(true);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue