mirror of https://github.com/procxx/kepka.git
Alpha 1.1.3: Fix some render in macOS.
This commit is contained in:
parent
413be7d76d
commit
e0978f86d1
|
@ -1972,7 +1972,7 @@ void HistoryGif::draw(Painter &p, const QRect &r, TextSelection selection, TimeM
|
||||||
if (displayMute) {
|
if (displayMute) {
|
||||||
_roundPlayback.reset();
|
_roundPlayback.reset();
|
||||||
} else if (_roundPlayback) {
|
} else if (_roundPlayback) {
|
||||||
auto value = _roundPlayback->value();
|
auto value = _roundPlayback->value(ms);
|
||||||
if (value > 0.) {
|
if (value > 0.) {
|
||||||
auto pen = st::historyVideoMessageProgressFg->p;
|
auto pen = st::historyVideoMessageProgressFg->p;
|
||||||
auto was = p.pen();
|
auto was = p.pen();
|
||||||
|
|
|
@ -140,7 +140,7 @@ void Float::prepareShadow() {
|
||||||
auto extend = 2 * st::lineWidth;
|
auto extend = 2 * st::lineWidth;
|
||||||
p.drawEllipse(getInnerRect().marginsAdded(QMargins(extend, extend, extend, extend)));
|
p.drawEllipse(getInnerRect().marginsAdded(QMargins(extend, extend, extend, extend)));
|
||||||
}
|
}
|
||||||
_shadow = App::pixmapFromImageInPlace(Images::prepareBlur(shadow));
|
_shadow = App::pixmapFromImageInPlace(Images::prepareBlur(std::move(shadow)));
|
||||||
}
|
}
|
||||||
|
|
||||||
QRect Float::getInnerRect() const {
|
QRect Float::getInnerRect() const {
|
||||||
|
@ -161,7 +161,7 @@ void Float::paintEvent(QPaintEvent *e) {
|
||||||
auto inner = getInnerRect();
|
auto inner = getInnerRect();
|
||||||
p.drawImage(inner.topLeft(), _frame);
|
p.drawImage(inner.topLeft(), _frame);
|
||||||
|
|
||||||
auto progress = _roundPlayback ? _roundPlayback->value() : 1.;
|
auto progress = _roundPlayback ? _roundPlayback->value(getms()) : 1.;
|
||||||
if (progress > 0.) {
|
if (progress > 0.) {
|
||||||
auto pen = st::historyVideoMessageProgressFg->p;
|
auto pen = st::historyVideoMessageProgressFg->p;
|
||||||
auto was = p.pen();
|
auto was = p.pen();
|
||||||
|
|
|
@ -88,6 +88,11 @@ float64 Playback::value() const {
|
||||||
return qMin(a_value.current(), 1.);
|
return qMin(a_value.current(), 1.);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
float64 Playback::value(TimeMs ms) {
|
||||||
|
_a_value.step(ms);
|
||||||
|
return value();
|
||||||
|
}
|
||||||
|
|
||||||
void Playback::setValue(float64 value, bool animated) {
|
void Playback::setValue(float64 value, bool animated) {
|
||||||
if (animated) {
|
if (animated) {
|
||||||
a_value.start(value);
|
a_value.start(value);
|
||||||
|
|
|
@ -41,6 +41,7 @@ public:
|
||||||
}
|
}
|
||||||
void setValue(float64 value, bool animated);
|
void setValue(float64 value, bool animated);
|
||||||
float64 value() const;
|
float64 value() const;
|
||||||
|
float64 value(TimeMs ms);
|
||||||
|
|
||||||
void updateState(const Player::TrackState &state);
|
void updateState(const Player::TrackState &state);
|
||||||
void updateLoadingState(float64 progress);
|
void updateLoadingState(float64 progress);
|
||||||
|
|
|
@ -242,7 +242,7 @@ void Photo::paint(Painter &p, const QRect &clip, TextSelection selection, const
|
||||||
if (_goodLoaded || _data->thumb->loaded()) {
|
if (_goodLoaded || _data->thumb->loaded()) {
|
||||||
auto img = (_data->loaded() ? _data->full : (_data->medium->loaded() ? _data->medium : _data->thumb))->pix().toImage();
|
auto img = (_data->loaded() ? _data->full : (_data->medium->loaded() ? _data->medium : _data->thumb))->pix().toImage();
|
||||||
if (!_goodLoaded) {
|
if (!_goodLoaded) {
|
||||||
img = Images::prepareBlur(img);
|
img = Images::prepareBlur(std::move(img));
|
||||||
}
|
}
|
||||||
if (img.width() == img.height()) {
|
if (img.width() == img.height()) {
|
||||||
if (img.width() != size) {
|
if (img.width() != size) {
|
||||||
|
@ -344,7 +344,7 @@ void Video::paint(Painter &p, const QRect &clip, TextSelection selection, const
|
||||||
_thumbLoaded = thumbLoaded;
|
_thumbLoaded = thumbLoaded;
|
||||||
|
|
||||||
if (_thumbLoaded && !_data->thumb->isNull()) {
|
if (_thumbLoaded && !_data->thumb->isNull()) {
|
||||||
int32 size = _width * cIntRetinaFactor();
|
auto size = _width * cIntRetinaFactor();
|
||||||
auto img = Images::prepareBlur(_data->thumb->pix().toImage());
|
auto img = Images::prepareBlur(_data->thumb->pix().toImage());
|
||||||
if (img.width() == img.height()) {
|
if (img.width() == img.height()) {
|
||||||
if (img.width() != size) {
|
if (img.width() != size) {
|
||||||
|
|
|
@ -60,9 +60,11 @@ const QPixmap &circleMask(int width, int height) {
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
QImage prepareBlur(QImage img) {
|
QImage prepareBlur(QImage img) {
|
||||||
QImage::Format fmt = img.format();
|
auto ratio = img.devicePixelRatio();
|
||||||
|
auto fmt = img.format();
|
||||||
if (fmt != QImage::Format_RGB32 && fmt != QImage::Format_ARGB32_Premultiplied) {
|
if (fmt != QImage::Format_RGB32 && fmt != QImage::Format_ARGB32_Premultiplied) {
|
||||||
img = img.convertToFormat(QImage::Format_ARGB32_Premultiplied);
|
img = img.convertToFormat(QImage::Format_ARGB32_Premultiplied);
|
||||||
|
img.setDevicePixelRatio(ratio);
|
||||||
t_assert(!img.isNull());
|
t_assert(!img.isNull());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,8 +87,9 @@ QImage prepareBlur(QImage img) {
|
||||||
p.fillRect(0, 0, w, h, Qt::transparent);
|
p.fillRect(0, 0, w, h, Qt::transparent);
|
||||||
p.drawImage(QRect(radius, radius, w - 2 * radius, h - 2 * radius), img, QRect(0, 0, w, h));
|
p.drawImage(QRect(radius, radius, w - 2 * radius, h - 2 * radius), img, QRect(0, 0, w, h));
|
||||||
}
|
}
|
||||||
QImage was = img;
|
imgsmall.setDevicePixelRatio(ratio);
|
||||||
img = imgsmall;
|
auto was = img;
|
||||||
|
img = std::move(imgsmall);
|
||||||
imgsmall = QImage();
|
imgsmall = QImage();
|
||||||
t_assert(!img.isNull());
|
t_assert(!img.isNull());
|
||||||
|
|
||||||
|
@ -293,7 +296,7 @@ QImage prepareOpaque(QImage image) {
|
||||||
QImage prepare(QImage img, int w, int h, Images::Options options, int outerw, int outerh) {
|
QImage prepare(QImage img, int w, int h, Images::Options options, int outerw, int outerh) {
|
||||||
t_assert(!img.isNull());
|
t_assert(!img.isNull());
|
||||||
if (options.testFlag(Images::Option::Blurred)) {
|
if (options.testFlag(Images::Option::Blurred)) {
|
||||||
img = prepareBlur(img);
|
img = prepareBlur(std::move(img));
|
||||||
t_assert(!img.isNull());
|
t_assert(!img.isNull());
|
||||||
}
|
}
|
||||||
if (w <= 0 || (w == img.width() && (h <= 0 || h == img.height()))) {
|
if (w <= 0 || (w == img.width() && (h <= 0 || h == img.height()))) {
|
||||||
|
@ -752,7 +755,7 @@ QPixmap Image::pixBlurredColoredNoCache(style::color add, int32 w, int32 h) cons
|
||||||
restore();
|
restore();
|
||||||
if (_data.isNull()) return blank()->pix();
|
if (_data.isNull()) return blank()->pix();
|
||||||
|
|
||||||
QImage img = Images::prepareBlur(_data.toImage());
|
auto img = Images::prepareBlur(_data.toImage());
|
||||||
if (h <= 0) {
|
if (h <= 0) {
|
||||||
img = img.scaledToWidth(w, Qt::SmoothTransformation);
|
img = img.scaledToWidth(w, Qt::SmoothTransformation);
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue