Refactored edit_caption_box.

This commit is contained in:
23rd 2019-03-21 15:28:42 +03:00 committed by John Preston
parent 59c73a4814
commit 5d04842a80
1 changed files with 27 additions and 27 deletions

View File

@ -76,7 +76,7 @@ EditCaptionBox::EditCaptionBox(
if (!image) { if (!image) {
_thumbw = 0; _thumbw = 0;
} else { } else {
int32 tw = image->width(), th = image->height(); const auto tw = image->width(), th = image->height();
if (tw > th) { if (tw > th) {
_thumbw = (tw * st::msgFileThumbSize) / th; _thumbw = (tw * st::msgFileThumbSize) / th;
} else { } else {
@ -84,7 +84,7 @@ EditCaptionBox::EditCaptionBox(
} }
_thumbnailImage = image; _thumbnailImage = image;
_refreshThumbnail = [=] { _refreshThumbnail = [=] {
auto options = Images::Option::Smooth const auto options = Images::Option::Smooth
| Images::Option::RoundedSmall | Images::Option::RoundedSmall
| Images::Option::RoundedTopLeft | Images::Option::RoundedTopLeft
| Images::Option::RoundedTopRight | Images::Option::RoundedTopRight
@ -101,7 +101,7 @@ EditCaptionBox::EditCaptionBox(
} }
if (doc) { if (doc) {
auto nameString = doc->isVoiceMessage() const auto nameString = doc->isVoiceMessage()
? lang(lng_media_audio) ? lang(lng_media_audio)
: doc->composeNameString(); : doc->composeNameString();
_name.setText( _name.setText(
@ -109,7 +109,7 @@ EditCaptionBox::EditCaptionBox(
nameString, nameString,
Ui::NameTextOptions()); Ui::NameTextOptions());
_status = formatSizeText(doc->size); _status = formatSizeText(doc->size);
_statusw = qMax( _statusw = std::max(
_name.maxWidth(), _name.maxWidth(),
st::normalFont->width(_status)); st::normalFont->width(_status));
_isImage = doc->isImage(); _isImage = doc->isImage();
@ -122,12 +122,12 @@ EditCaptionBox::EditCaptionBox(
if (!image) { if (!image) {
image = Image::BlankMedia(); image = Image::BlankMedia();
} }
int32 maxW = 0, maxH = 0; auto maxW = 0, maxH = 0;
int32 limitW = st::sendMediaPreviewSize; const auto limitW = st::sendMediaPreviewSize;
int32 limitH = std::min(st::confirmMaxHeight, _gifh ? _gifh : INT_MAX); auto limitH = std::min(st::confirmMaxHeight, _gifh ? _gifh : INT_MAX);
if (_animated) { if (_animated) {
maxW = qMax(dimensions.width(), 1); maxW = std::max(dimensions.width(), 1);
maxH = qMax(dimensions.height(), 1); maxH = std::max(dimensions.height(), 1);
if (maxW * limitH > maxH * limitW) { if (maxW * limitH > maxH * limitW) {
if (maxW < limitW) { if (maxW < limitW) {
maxH = maxH * limitW / maxW; maxH = maxH * limitW / maxW;
@ -169,7 +169,7 @@ EditCaptionBox::EditCaptionBox(
_refreshThumbnail(); _refreshThumbnail();
const auto resizeDimensions = [&](int &thumbWidth, int &thumbHeight, int &thumbX) { const auto resizeDimensions = [&](int &thumbWidth, int &thumbHeight, int &thumbX) {
int32 tw = thumbWidth, th = thumbHeight; auto tw = thumbWidth, th = thumbHeight;
if (!tw || !th) { if (!tw || !th) {
tw = th = 1; tw = th = 1;
} }
@ -178,10 +178,10 @@ EditCaptionBox::EditCaptionBox(
} else { } else {
thumbWidth = st::sendMediaPreviewSize; thumbWidth = st::sendMediaPreviewSize;
} }
int32 maxThumbHeight = qMin(qRound(1.5 * thumbWidth), limitH); const auto maxThumbHeight = std::min(int(std::round(1.5 * thumbWidth)), limitH);
thumbHeight = qRound(th * float64(thumbWidth) / tw); thumbHeight = int(std::round(th * float64(thumbWidth) / tw));
if (thumbHeight > maxThumbHeight) { if (thumbHeight > maxThumbHeight) {
thumbWidth = qRound(thumbWidth * float64(maxThumbHeight) / thumbHeight); thumbWidth = int(std::round(thumbWidth * float64(maxThumbHeight) / thumbHeight));
thumbHeight = maxThumbHeight; thumbHeight = maxThumbHeight;
if (thumbWidth < 10) { if (thumbWidth < 10) {
thumbWidth = 10; thumbWidth = 10;
@ -291,7 +291,7 @@ void EditCaptionBox::clipCallback(Media::Clip::Notification notification) {
} }
if (_gifPreview && _gifPreview->ready() && !_gifPreview->started()) { if (_gifPreview && _gifPreview->ready() && !_gifPreview->started()) {
auto s = QSize(_gifw, _gifh); const auto s = QSize(_gifw, _gifh);
_gifPreview->start(s.width(), s.height(), s.width(), s.height(), ImageRoundRadius::None, RectPart::None); _gifPreview->start(s.width(), s.height(), s.width(), s.height(), ImageRoundRadius::None, RectPart::None);
} }
@ -394,9 +394,9 @@ void EditCaptionBox::paintEvent(QPaintEvent *e) {
p.fillRect(_thumbx + _thumbw, st::boxPhotoPadding.top(), width() - st::boxPhotoPadding.right() - _thumbx - _thumbw, th, st::confirmBg); p.fillRect(_thumbx + _thumbw, st::boxPhotoPadding.top(), width() - st::boxPhotoPadding.right() - _thumbx - _thumbw, th, st::confirmBg);
} }
if (_gifPreview && _gifPreview->started()) { if (_gifPreview && _gifPreview->started()) {
auto s = QSize(_gifw, _gifh); const auto s = QSize(_gifw, _gifh);
auto paused = _controller->isGifPausedAtLeastFor(Window::GifPauseReason::Layer); const auto paused = _controller->isGifPausedAtLeastFor(Window::GifPauseReason::Layer);
auto frame = _gifPreview->current(s.width(), s.height(), s.width(), s.height(), ImageRoundRadius::None, RectPart::None, paused ? 0 : crl::now()); const auto frame = _gifPreview->current(s.width(), s.height(), s.width(), s.height(), ImageRoundRadius::None, RectPart::None, paused ? 0 : crl::now());
p.drawPixmap(_gifx, st::boxPhotoPadding.top(), frame); p.drawPixmap(_gifx, st::boxPhotoPadding.top(), frame);
} else { } else {
const auto offset = _gifh ? ((_gifh - _thumbh) / 2) : 0; const auto offset = _gifh ? ((_gifh - _thumbh) / 2) : 0;
@ -412,13 +412,13 @@ void EditCaptionBox::paintEvent(QPaintEvent *e) {
p.drawEllipse(inner); p.drawEllipse(inner);
} }
auto icon = &st::historyFileInPlay; const auto icon = &st::historyFileInPlay;
icon->paintInCenter(p, inner); icon->paintInCenter(p, inner);
} }
} else if (_doc) { } else if (_doc) {
int32 w = width() - st::boxPhotoPadding.left() - st::boxPhotoPadding.right(); const auto w = width() - st::boxPhotoPadding.left() - st::boxPhotoPadding.right();
int32 h = _thumbw ? (0 + st::msgFileThumbSize + 0) : (0 + st::msgFileSize + 0); const auto h = _thumbw ? (0 + st::msgFileThumbSize + 0) : (0 + st::msgFileSize + 0);
int32 nameleft = 0, nametop = 0, nameright = 0, statustop = 0; auto nameleft = 0, nametop = 0, nameright = 0, statustop = 0;
if (_thumbw) { if (_thumbw) {
nameleft = 0 + st::msgFileThumbSize + st::msgFileThumbPadding.right(); nameleft = 0 + st::msgFileThumbSize + st::msgFileThumbPadding.right();
nametop = st::msgFileThumbNameTop - st::msgFileThumbPadding.top(); nametop = st::msgFileThumbNameTop - st::msgFileThumbPadding.top();
@ -430,12 +430,12 @@ void EditCaptionBox::paintEvent(QPaintEvent *e) {
nameright = 0; nameright = 0;
statustop = st::msgFileStatusTop - st::msgFilePadding.top(); statustop = st::msgFileStatusTop - st::msgFilePadding.top();
} }
int32 namewidth = w - nameleft - 0; const auto namewidth = w - nameleft - 0;
if (namewidth > _statusw) { if (namewidth > _statusw) {
//w -= (namewidth - _statusw); //w -= (namewidth - _statusw);
//namewidth = _statusw; //namewidth = _statusw;
} }
int32 x = (width() - w) / 2, y = st::boxPhotoPadding.top(); const auto x = (width() - w) / 2, y = st::boxPhotoPadding.top();
// App::roundRect(p, x, y, w, h, st::msgInBg, MessageInCorners, &st::msgInShadow); // App::roundRect(p, x, y, w, h, st::msgInBg, MessageInCorners, &st::msgInShadow);
@ -443,7 +443,7 @@ void EditCaptionBox::paintEvent(QPaintEvent *e) {
QRect rthumb(rtlrect(x + 0, y + 0, st::msgFileThumbSize, st::msgFileThumbSize, width())); QRect rthumb(rtlrect(x + 0, y + 0, st::msgFileThumbSize, st::msgFileThumbSize, width()));
p.drawPixmap(rthumb.topLeft(), _thumb); p.drawPixmap(rthumb.topLeft(), _thumb);
} else { } else {
QRect inner(rtlrect(x + 0, y + 0, st::msgFileSize, st::msgFileSize, width())); const QRect inner(rtlrect(x + 0, y + 0, st::msgFileSize, st::msgFileSize, width()));
p.setPen(Qt::NoPen); p.setPen(Qt::NoPen);
p.setBrush(st::msgFileInBg); p.setBrush(st::msgFileInBg);
@ -452,14 +452,14 @@ void EditCaptionBox::paintEvent(QPaintEvent *e) {
p.drawEllipse(inner); p.drawEllipse(inner);
} }
auto icon = &(_isAudio ? st::historyFileInPlay : _isImage ? st::historyFileInImage : st::historyFileInDocument); const auto icon = &(_isAudio ? st::historyFileInPlay : _isImage ? st::historyFileInImage : st::historyFileInDocument);
icon->paintInCenter(p, inner); icon->paintInCenter(p, inner);
} }
p.setFont(st::semiboldFont); p.setFont(st::semiboldFont);
p.setPen(st::historyFileNameInFg); p.setPen(st::historyFileNameInFg);
_name.drawLeftElided(p, x + nameleft, y + nametop, namewidth, width()); _name.drawLeftElided(p, x + nameleft, y + nametop, namewidth, width());
auto &status = st::mediaInFg; const auto &status = st::mediaInFg;
p.setFont(st::normalFont); p.setFont(st::normalFont);
p.setPen(status); p.setPen(status);
p.drawTextLeft(x + nameleft, y + statustop, width(), _status); p.drawTextLeft(x + nameleft, y + statustop, width(), _status);
@ -494,7 +494,7 @@ void EditCaptionBox::setInnerFocus() {
void EditCaptionBox::save() { void EditCaptionBox::save() {
if (_saveRequestId) return; if (_saveRequestId) return;
auto item = App::histItemById(_msgId); const auto item = App::histItemById(_msgId);
if (!item) { if (!item) {
_error = lang(lng_edit_deleted); _error = lang(lng_edit_deleted);
update(); update();