Preload animated emoji sticker

This commit is contained in:
morethanwords 2021-10-27 22:57:49 +03:00
parent 7e7eb78a8a
commit a5cb3b4af3
3 changed files with 27 additions and 3 deletions

View File

@ -55,6 +55,7 @@ export default class StickersHelper extends AutocompleteHelper {
this.lazyLoadQueue.clear();
}
appStickersManager.preloadAnimatedEmojiSticker(emoticon);
appStickersManager.getStickersByEmoticon(emoticon)
.then((stickers) => {
if(!middleware()) {

View File

@ -13,6 +13,10 @@ import AppStorage from '../storage';
import { MOUNT_CLASS_TO } from '../../config/debug';
import { forEachReverse } from '../../helpers/array';
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;
@ -144,11 +148,27 @@ export class AppStickersManager {
return pack ? appDocsManager.getDoc(pack.documents[0]) : undefined;
}
public preloadAnimatedEmojiSticker(emoji: string) {
public preloadAnimatedEmojiSticker(emoji: string, width?: number, height?: number) {
return this.getAnimatedEmojiStickerSet().then(() => {
const doc = this.getAnimatedEmojiSticker(emoji);
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});
});
}
});
}

View File

@ -732,7 +732,10 @@ class LottieLoader {
params.group = group;
const player = this.initPlayer(params.container, params);
if(group !== 'none') {
animationIntersector.addAnimation(player, group);
}
return player;
}