mirror of https://github.com/procxx/kepka.git
Fix crash in the EditCaptionBox.
This commit is contained in:
parent
fbb2bae99f
commit
e1d36cfd50
|
@ -72,31 +72,21 @@ EditCaptionBox::EditCaptionBox(
|
||||||
_isAllowedEditMedia = item->media()->allowsEditMedia();
|
_isAllowedEditMedia = item->media()->allowsEditMedia();
|
||||||
_isAlbum = !item->groupId().empty();
|
_isAlbum = !item->groupId().empty();
|
||||||
|
|
||||||
QSize dimensions;
|
auto dimensions = QSize();
|
||||||
auto image = (Image*)nullptr;
|
|
||||||
|
|
||||||
const auto media = item->media();
|
const auto media = item->media();
|
||||||
if (const auto photo = media->photo()) {
|
if (const auto photo = media->photo()) {
|
||||||
_photoMedia = photo->createMediaView();
|
_photoMedia = photo->createMediaView();
|
||||||
_photoMedia->wanted(PhotoSize::Large, _msgId);
|
_photoMedia->wanted(PhotoSize::Large, _msgId);
|
||||||
image = _photoMedia->image(PhotoSize::Large);
|
|
||||||
if (!image) {
|
|
||||||
image = _photoMedia->image(PhotoSize::Thumbnail);
|
|
||||||
if (!image) {
|
|
||||||
image = _photoMedia->image(PhotoSize::Small);
|
|
||||||
if (!image) {
|
|
||||||
image = _photoMedia->thumbnailInline();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
dimensions = _photoMedia->size(PhotoSize::Large);
|
dimensions = _photoMedia->size(PhotoSize::Large);
|
||||||
|
if (dimensions.isEmpty()) {
|
||||||
|
dimensions = QSize(1, 1);
|
||||||
|
}
|
||||||
_photo = true;
|
_photo = true;
|
||||||
} else if (const auto document = media->document()) {
|
} else if (const auto document = media->document()) {
|
||||||
_documentMedia = document->createMediaView();
|
_documentMedia = document->createMediaView();
|
||||||
_documentMedia->thumbnailWanted(_msgId);
|
_documentMedia->thumbnailWanted(_msgId);
|
||||||
image = _documentMedia->thumbnail();
|
dimensions = _documentMedia->thumbnail()
|
||||||
dimensions = image
|
? _documentMedia->thumbnail()->size()
|
||||||
? image->size()
|
|
||||||
: document->dimensions;
|
: document->dimensions;
|
||||||
if (document->isAnimation()) {
|
if (document->isAnimation()) {
|
||||||
_gifw = style::ConvertScale(document->dimensions.width());
|
_gifw = style::ConvertScale(document->dimensions.width());
|
||||||
|
@ -107,24 +97,42 @@ EditCaptionBox::EditCaptionBox(
|
||||||
} else {
|
} else {
|
||||||
_doc = true;
|
_doc = true;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
Unexpected("Photo or document should be set.");
|
||||||
}
|
}
|
||||||
const auto editData = PrepareEditText(item);
|
const auto editData = PrepareEditText(item);
|
||||||
|
|
||||||
if (!_animated
|
const auto computeImage = [=] {
|
||||||
&& (dimensions.isEmpty()
|
if (_documentMedia) {
|
||||||
|| _documentMedia
|
return _documentMedia->thumbnail();
|
||||||
|| (!_photoMedia && !image))) {
|
} else if (const auto large = _photoMedia->image(PhotoSize::Large)) {
|
||||||
if (!image) {
|
return large;
|
||||||
_thumbw = 0;
|
} else if (const auto thumbnail = _photoMedia->image(
|
||||||
|
PhotoSize::Thumbnail)) {
|
||||||
|
return thumbnail;
|
||||||
|
} else if (const auto small = _photoMedia->image(PhotoSize::Small)) {
|
||||||
|
return small;
|
||||||
} else {
|
} else {
|
||||||
const auto tw = image->width(), th = image->height();
|
return _photoMedia->thumbnailInline();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!_animated && _documentMedia) {
|
||||||
|
if (dimensions.isEmpty()) {
|
||||||
|
_thumbw = 0;
|
||||||
|
_thumbnailImageLoaded = true;
|
||||||
|
} else {
|
||||||
|
const auto tw = dimensions.width(), th = dimensions.height();
|
||||||
if (tw > th) {
|
if (tw > th) {
|
||||||
_thumbw = (tw * st::msgFileThumbSize) / th;
|
_thumbw = (tw * st::msgFileThumbSize) / th;
|
||||||
} else {
|
} else {
|
||||||
_thumbw = st::msgFileThumbSize;
|
_thumbw = st::msgFileThumbSize;
|
||||||
}
|
}
|
||||||
_thumbnailImage = image;
|
|
||||||
_refreshThumbnail = [=] {
|
_refreshThumbnail = [=] {
|
||||||
|
const auto image = computeImage();
|
||||||
|
if (!image) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
const auto options = Images::Option::Smooth
|
const auto options = Images::Option::Smooth
|
||||||
| Images::Option::RoundedSmall
|
| Images::Option::RoundedSmall
|
||||||
| Images::Option::RoundedTopLeft
|
| Images::Option::RoundedTopLeft
|
||||||
|
@ -138,7 +146,9 @@ EditCaptionBox::EditCaptionBox(
|
||||||
options,
|
options,
|
||||||
st::msgFileThumbSize,
|
st::msgFileThumbSize,
|
||||||
st::msgFileThumbSize));
|
st::msgFileThumbSize));
|
||||||
|
_thumbnailImageLoaded = true;
|
||||||
};
|
};
|
||||||
|
_refreshThumbnail();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_documentMedia) {
|
if (_documentMedia) {
|
||||||
|
@ -151,13 +161,7 @@ EditCaptionBox::EditCaptionBox(
|
||||||
_isAudio = document->isVoiceMessage()
|
_isAudio = document->isVoiceMessage()
|
||||||
|| document->isAudioFile();
|
|| document->isAudioFile();
|
||||||
}
|
}
|
||||||
if (_refreshThumbnail) {
|
|
||||||
_refreshThumbnail();
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if (!image && !_photoMedia) {
|
|
||||||
image = Image::BlankMedia();
|
|
||||||
}
|
|
||||||
auto maxW = 0, maxH = 0;
|
auto maxW = 0, maxH = 0;
|
||||||
const auto limitW = st::sendMediaPreviewSize;
|
const auto limitW = st::sendMediaPreviewSize;
|
||||||
auto limitH = std::min(st::confirmMaxHeight, _gifh ? _gifh : INT_MAX);
|
auto limitH = std::min(st::confirmMaxHeight, _gifh ? _gifh : INT_MAX);
|
||||||
|
@ -175,35 +179,38 @@ EditCaptionBox::EditCaptionBox(
|
||||||
maxH = limitH;
|
maxH = limitH;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_thumbnailImage = image;
|
|
||||||
_refreshThumbnail = [=] {
|
_refreshThumbnail = [=] {
|
||||||
|
const auto image = computeImage();
|
||||||
|
const auto use = image ? image : Image::BlankMedia().get();
|
||||||
const auto options = Images::Option::Smooth
|
const auto options = Images::Option::Smooth
|
||||||
| Images::Option::Blurred;
|
| Images::Option::Blurred;
|
||||||
_thumb = image->pixNoCache(
|
_thumb = use->pixNoCache(
|
||||||
maxW * cIntRetinaFactor(),
|
maxW * cIntRetinaFactor(),
|
||||||
maxH * cIntRetinaFactor(),
|
maxH * cIntRetinaFactor(),
|
||||||
options,
|
options,
|
||||||
maxW,
|
maxW,
|
||||||
maxH);
|
maxH);
|
||||||
|
_thumbnailImageLoaded = true;
|
||||||
};
|
};
|
||||||
prepareStreamedPreview();
|
prepareStreamedPreview();
|
||||||
} else {
|
} else {
|
||||||
|
Assert(_photoMedia != nullptr);
|
||||||
|
|
||||||
maxW = dimensions.width();
|
maxW = dimensions.width();
|
||||||
maxH = dimensions.height();
|
maxH = dimensions.height();
|
||||||
_thumbnailImage = image;
|
|
||||||
_refreshThumbnail = [=] {
|
_refreshThumbnail = [=] {
|
||||||
const auto photo = _photoMedia
|
const auto image = computeImage();
|
||||||
? _photoMedia->image(Data::PhotoSize::Large)
|
const auto photo = _photoMedia->image(Data::PhotoSize::Large);
|
||||||
: nullptr;
|
|
||||||
const auto use = photo
|
const auto use = photo
|
||||||
? photo
|
? photo
|
||||||
: _thumbnailImage
|
: image
|
||||||
? _thumbnailImage
|
? image
|
||||||
: Image::BlankMedia().get();
|
: Image::BlankMedia().get();
|
||||||
const auto options = Images::Option::Smooth
|
const auto options = Images::Option::Smooth
|
||||||
| ((_photoMedia && !photo)
|
| (photo
|
||||||
? Images::Option::Blurred
|
? Images::Option(0)
|
||||||
: Images::Option(0));
|
: Images::Option::Blurred);
|
||||||
|
_thumbnailImageLoaded = (photo != nullptr);
|
||||||
_thumb = use->pixNoCache(
|
_thumb = use->pixNoCache(
|
||||||
maxW * cIntRetinaFactor(),
|
maxW * cIntRetinaFactor(),
|
||||||
maxH * cIntRetinaFactor(),
|
maxH * cIntRetinaFactor(),
|
||||||
|
@ -276,35 +283,17 @@ EditCaptionBox::EditCaptionBox(
|
||||||
scaleThumbDown();
|
scaleThumbDown();
|
||||||
}
|
}
|
||||||
Assert(_animated || _photo || _doc);
|
Assert(_animated || _photo || _doc);
|
||||||
|
Assert(_thumbnailImageLoaded || _refreshThumbnail);
|
||||||
|
|
||||||
_thumbnailImageLoaded = _photoMedia
|
|
||||||
? (_photoMedia->image(Data::PhotoSize::Large) != nullptr)
|
|
||||||
: _thumbnailImage
|
|
||||||
? true
|
|
||||||
: _documentMedia
|
|
||||||
? !_documentMedia->owner()->hasThumbnail()
|
|
||||||
: true;
|
|
||||||
if (!_thumbnailImageLoaded) {
|
if (!_thumbnailImageLoaded) {
|
||||||
subscribe(_controller->session().downloaderTaskFinished(), [=] {
|
subscribe(_controller->session().downloaderTaskFinished(), [=] {
|
||||||
if (_thumbnailImageLoaded) {
|
if (_thumbnailImageLoaded
|
||||||
|
|| (_photoMedia && !_photoMedia->image(PhotoSize::Large))
|
||||||
|
|| (_documentMedia && !_documentMedia->thumbnail())) {
|
||||||
return;
|
return;
|
||||||
} else if (!_thumbnailImage
|
|
||||||
&& _photoMedia
|
|
||||||
&& _photoMedia->image(PhotoSize::Large)) {
|
|
||||||
_thumbnailImage = _photoMedia->image(PhotoSize::Large);
|
|
||||||
} else if (!_thumbnailImage
|
|
||||||
&& _documentMedia
|
|
||||||
&& _documentMedia->owner()->hasThumbnail()) {
|
|
||||||
_thumbnailImage = _documentMedia->thumbnail();
|
|
||||||
}
|
|
||||||
if (_thumbnailImage) {
|
|
||||||
_thumbnailImageLoaded = !_photoMedia
|
|
||||||
|| _photoMedia->image(PhotoSize::Large);
|
|
||||||
if (_thumbnailImageLoaded) {
|
|
||||||
_refreshThumbnail();
|
|
||||||
update();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
_refreshThumbnail();
|
||||||
|
update();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
_field.create(
|
_field.create(
|
||||||
|
|
|
@ -108,7 +108,6 @@ private:
|
||||||
FullMsgId _msgId;
|
FullMsgId _msgId;
|
||||||
std::shared_ptr<Data::PhotoMedia> _photoMedia;
|
std::shared_ptr<Data::PhotoMedia> _photoMedia;
|
||||||
std::shared_ptr<Data::DocumentMedia> _documentMedia;
|
std::shared_ptr<Data::DocumentMedia> _documentMedia;
|
||||||
Image *_thumbnailImage = nullptr;
|
|
||||||
bool _thumbnailImageLoaded = false;
|
bool _thumbnailImageLoaded = false;
|
||||||
Fn<void()> _refreshThumbnail;
|
Fn<void()> _refreshThumbnail;
|
||||||
bool _animated = false;
|
bool _animated = false;
|
||||||
|
|
Loading…
Reference in New Issue