mirror of
https://github.com/pyrogram/pyrogram
synced 2025-08-30 05:48:14 +00:00
Fix determining video sticker resolution. Add sticker duration to Sticker type (#1065)
This commit is contained in:
parent
6c34c83a3e
commit
95de5f7eae
@ -50,9 +50,10 @@ class GetCustomEmojiStickers:
|
|||||||
|
|
||||||
sticker = await types.Sticker._parse(
|
sticker = await types.Sticker._parse(
|
||||||
self, item,
|
self, item,
|
||||||
attributes[raw.types.DocumentAttributeImageSize],
|
attributes[raw.types.DocumentAttributeImageSize] if raw.types.DocumentAttributeImageSize in attributes else None,
|
||||||
attributes[raw.types.DocumentAttributeCustomEmoji],
|
attributes[raw.types.DocumentAttributeCustomEmoji],
|
||||||
attributes[raw.types.DocumentAttributeFilename].file_name
|
attributes[raw.types.DocumentAttributeFilename].file_name,
|
||||||
|
attributes[raw.types.DocumentAttributeVideo] if raw.types.DocumentAttributeVideo in attributes else None
|
||||||
)
|
)
|
||||||
|
|
||||||
stickers.append(sticker)
|
stickers.append(sticker)
|
||||||
|
@ -700,7 +700,8 @@ class Message(Object, Update):
|
|||||||
client, doc,
|
client, doc,
|
||||||
attributes.get(raw.types.DocumentAttributeImageSize, None),
|
attributes.get(raw.types.DocumentAttributeImageSize, None),
|
||||||
attributes[raw.types.DocumentAttributeSticker],
|
attributes[raw.types.DocumentAttributeSticker],
|
||||||
file_name
|
file_name,
|
||||||
|
attributes.get(raw.types.DocumentAttributeVideo, None)
|
||||||
)
|
)
|
||||||
media_type = enums.MessageMediaType.STICKER
|
media_type = enums.MessageMediaType.STICKER
|
||||||
elif raw.types.DocumentAttributeVideo in attributes:
|
elif raw.types.DocumentAttributeVideo in attributes:
|
||||||
|
@ -50,6 +50,9 @@ class Sticker(Object):
|
|||||||
is_video (``bool``):
|
is_video (``bool``):
|
||||||
True, if the sticker is a video sticker
|
True, if the sticker is a video sticker
|
||||||
|
|
||||||
|
duration (``int``):
|
||||||
|
Video sticker duration in seconds.
|
||||||
|
|
||||||
file_name (``str``, *optional*):
|
file_name (``str``, *optional*):
|
||||||
Sticker file name.
|
Sticker file name.
|
||||||
|
|
||||||
@ -84,6 +87,7 @@ class Sticker(Object):
|
|||||||
height: int,
|
height: int,
|
||||||
is_animated: bool,
|
is_animated: bool,
|
||||||
is_video: bool,
|
is_video: bool,
|
||||||
|
duration: int = None,
|
||||||
file_name: str = None,
|
file_name: str = None,
|
||||||
mime_type: str = None,
|
mime_type: str = None,
|
||||||
file_size: int = None,
|
file_size: int = None,
|
||||||
@ -148,7 +152,8 @@ class Sticker(Object):
|
|||||||
sticker: "raw.types.Document",
|
sticker: "raw.types.Document",
|
||||||
image_size_attributes: "raw.types.DocumentAttributeImageSize",
|
image_size_attributes: "raw.types.DocumentAttributeImageSize",
|
||||||
sticker_attributes: "raw.types.DocumentAttributeSticker",
|
sticker_attributes: "raw.types.DocumentAttributeSticker",
|
||||||
file_name: str
|
file_name: str,
|
||||||
|
video_attributes: "raw.types.DocumentAttributeVideo"
|
||||||
) -> "Sticker":
|
) -> "Sticker":
|
||||||
sticker_set = sticker_attributes.stickerset
|
sticker_set = sticker_attributes.stickerset
|
||||||
|
|
||||||
@ -170,10 +175,11 @@ class Sticker(Object):
|
|||||||
file_unique_type=FileUniqueType.DOCUMENT,
|
file_unique_type=FileUniqueType.DOCUMENT,
|
||||||
media_id=sticker.id
|
media_id=sticker.id
|
||||||
).encode(),
|
).encode(),
|
||||||
width=image_size_attributes.w if image_size_attributes else 512,
|
width=image_size_attributes.w if image_size_attributes else (video_attributes.w if video_attributes else 512),
|
||||||
height=image_size_attributes.h if image_size_attributes else 512,
|
height=image_size_attributes.h if image_size_attributes else (video_attributes.h if video_attributes else 512),
|
||||||
is_animated=sticker.mime_type == "application/x-tgsticker",
|
is_animated=sticker.mime_type == "application/x-tgsticker",
|
||||||
is_video=sticker.mime_type == "video/webm",
|
is_video=sticker.mime_type == "video/webm",
|
||||||
|
duration=video_attributes.duration if video_attributes else None,
|
||||||
# TODO: mask_position
|
# TODO: mask_position
|
||||||
set_name=set_name,
|
set_name=set_name,
|
||||||
emoji=sticker_attributes.alt or None,
|
emoji=sticker_attributes.alt or None,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user