Preload animated emoji sticker
This commit is contained in:
parent
7e7eb78a8a
commit
a5cb3b4af3
@ -55,6 +55,7 @@ export default class StickersHelper extends AutocompleteHelper {
|
|||||||
this.lazyLoadQueue.clear();
|
this.lazyLoadQueue.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
appStickersManager.preloadAnimatedEmojiSticker(emoticon);
|
||||||
appStickersManager.getStickersByEmoticon(emoticon)
|
appStickersManager.getStickersByEmoticon(emoticon)
|
||||||
.then((stickers) => {
|
.then((stickers) => {
|
||||||
if(!middleware()) {
|
if(!middleware()) {
|
||||||
|
@ -13,6 +13,10 @@ import AppStorage from '../storage';
|
|||||||
import { MOUNT_CLASS_TO } from '../../config/debug';
|
import { MOUNT_CLASS_TO } from '../../config/debug';
|
||||||
import { forEachReverse } from '../../helpers/array';
|
import { forEachReverse } from '../../helpers/array';
|
||||||
import DATABASE_STATE from '../../config/databases/state';
|
import DATABASE_STATE from '../../config/databases/state';
|
||||||
|
import { readBlobAsText } from '../../helpers/blob';
|
||||||
|
import lottieLoader from '../lottieLoader';
|
||||||
|
import mediaSizes from '../../helpers/mediaSizes';
|
||||||
|
import { getEmojiToneIndex } from '../../vendor/emoji';
|
||||||
|
|
||||||
const CACHE_TIME = 3600e3;
|
const CACHE_TIME = 3600e3;
|
||||||
|
|
||||||
@ -144,11 +148,27 @@ export class AppStickersManager {
|
|||||||
return pack ? appDocsManager.getDoc(pack.documents[0]) : undefined;
|
return pack ? appDocsManager.getDoc(pack.documents[0]) : undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
public preloadAnimatedEmojiSticker(emoji: string) {
|
public preloadAnimatedEmojiSticker(emoji: string, width?: number, height?: number) {
|
||||||
return this.getAnimatedEmojiStickerSet().then(() => {
|
return this.getAnimatedEmojiStickerSet().then(() => {
|
||||||
const doc = this.getAnimatedEmojiSticker(emoji);
|
const doc = this.getAnimatedEmojiSticker(emoji);
|
||||||
if(doc) {
|
if(doc) {
|
||||||
return appDocsManager.downloadDoc(doc);
|
return appDocsManager.downloadDoc(doc)
|
||||||
|
.then(readBlobAsText)
|
||||||
|
.then(async(json) => {
|
||||||
|
const mediaSize = mediaSizes.active.emojiSticker;
|
||||||
|
const toneIndex = getEmojiToneIndex(emoji);
|
||||||
|
const animation = await lottieLoader.loadAnimationWorker({
|
||||||
|
container: undefined,
|
||||||
|
animationData: json,
|
||||||
|
width: width ?? mediaSize.width,
|
||||||
|
height: height ?? mediaSize.height
|
||||||
|
}, 'none', toneIndex);
|
||||||
|
|
||||||
|
animation.addEventListener('firstFrame', () => {
|
||||||
|
appDocsManager.saveLottiePreview(doc, animation.canvas, toneIndex);
|
||||||
|
animation.remove();
|
||||||
|
}, {once: true});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -732,7 +732,10 @@ class LottieLoader {
|
|||||||
params.group = group;
|
params.group = group;
|
||||||
|
|
||||||
const player = this.initPlayer(params.container, params);
|
const player = this.initPlayer(params.container, params);
|
||||||
animationIntersector.addAnimation(player, group);
|
|
||||||
|
if(group !== 'none') {
|
||||||
|
animationIntersector.addAnimation(player, group);
|
||||||
|
}
|
||||||
|
|
||||||
return player;
|
return player;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user