Skip to content

Commit

Permalink
Push From Landun: update SDK
Browse files Browse the repository at this point in the history
  • Loading branch information
libpag-pag committed Nov 13, 2024
1 parent fbcf52a commit 21e17f4
Show file tree
Hide file tree
Showing 10 changed files with 56 additions and 42 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@
#import <UIKit/UIKit.h>
#import "PAGComposition.h"

NS_ASSUME_NONNULL_BEGIN

/**
* PAGDecoder provides a utility to read image frames directly from a PAGComposition, and caches the
* image frames as a sequence file on the disk, which may significantly speed up the reading process
Expand Down Expand Up @@ -84,14 +86,14 @@ PAG_API @interface PAGDecoder : NSObject
* if failed. Note that caller must ensure that the rowBytes stays the same throughout every copying
* call. Otherwise, it may return false.
*/
- (BOOL)copyFrameTo:(void* _Nonnull)pixels rowBytes:(size_t)rowBytes at:(NSInteger)index;
- (BOOL)copyFrameTo:(void*)pixels rowBytes:(size_t)rowBytes at:(NSInteger)index;

/**
* Reads pixels of the image frame at the given index into the specified CVPixelBuffer. Returns
* false if failed. Reading image frames into HardwareBuffer usually has better performance than
* reading into memory.
*/
- (BOOL)readFrame:(NSInteger)index to:(CVPixelBufferRef _Nonnull)pixelBuffer;
- (BOOL)readFrame:(NSInteger)index to:(CVPixelBufferRef)pixelBuffer;

/**
* Returns the image frame at the specified index. Note that this method must be called while the
Expand All @@ -101,3 +103,5 @@ PAG_API @interface PAGDecoder : NSObject
- (nullable UIImage*)frameAtIndex:(NSInteger)index;

@end

NS_ASSUME_NONNULL_END
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@
#import <UIKit/UIKit.h>
#import "PAGComposition.h"

NS_ASSUME_NONNULL_BEGIN

@class PAGImageView;

@protocol PAGImageViewListener <NSObject>
Expand All @@ -28,29 +30,29 @@
* Notifies the beginning of the animation. It can be called from either the UI thread or the thread
* that calls the play method.
*/
- (void)onAnimationStart:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationStart:(PAGImageView*)pagView;

/**
* Notifies the end of the animation. It can only be called from the UI thread.
*/
- (void)onAnimationEnd:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationEnd:(PAGImageView*)pagView;

/**
* Notifies the cancellation of the animation. It can be called from either the UI thread or the
* thread that calls the stop method.
*/
- (void)onAnimationCancel:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationCancel:(PAGImageView*)pagView;

/**
* Notifies the repetition of the animation. It can only be called from the UI thread.
*/
- (void)onAnimationRepeat:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationRepeat:(PAGImageView*)pagView;

/**
* Notifies another frame of the animation has occurred. It may be called from an arbitrary
* thread if the animation is running asynchronously.
*/
- (void)onAnimationUpdate:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationUpdate:(PAGImageView*)pagView;

@end

Expand Down Expand Up @@ -80,14 +82,14 @@ PAG_API @interface PAGImageView : UIImageView
* composition is already added to another PAGImageView, it will be removed from the previous
* PAGImageView.
*/
- (void)setComposition:(nullable PAGComposition*)newComposition;
- (void)setComposition:(PAGComposition*)newComposition;

/**
* Sets a new PAGComposition and the maxFrameRate limit to the PAGImageView. Note: If the
* composition is already added to another PAGImageView, it will be removed from the previous
* PAGImageView.
*/
- (void)setComposition:(nullable PAGComposition*)newComposition maxFrameRate:(float)maxFrameRate;
- (void)setComposition:(PAGComposition*)newComposition maxFrameRate:(float)maxFrameRate;

/**
* Returns the file path set by the setPath() method.
Expand All @@ -98,28 +100,27 @@ PAG_API @interface PAGImageView : UIImageView
* Loads a pag file from the specified path, returns false if the file does not exist, or it is not
* a valid pag file.
*/
- (BOOL)setPath:(nullable NSString*)path;
- (BOOL)setPath:(NSString*)path;
/**
* Loads a pag file from the specified path with the maxFrameRate limit, returns false if the file
* does not exist, or it is not a valid pag file.
*/
- (BOOL)setPath:(nullable NSString*)filePath maxFrameRate:(float)maxFrameRate;
- (BOOL)setPath:(NSString*)filePath maxFrameRate:(float)maxFrameRate;

/**
* Asynchronously load a PAG file from the specific path, a block with PAGFile will be called
* when loading is complete. If loading fails, PAGFile will be set to nil.
*/
- (void)setPathAsync:(nullable NSString*)filePath
completionBlock:(void (^_Nullable)(PAGFile* __nullable))callback;
- (void)setPathAsync:(NSString*)filePath completionBlock:(void (^)(PAGFile*))callback;

/**
* Asynchronously load a PAG file from the specific path with the maxFrameRate limit, a block
* with PAGFile will be called when loading is complete. If loading fails, PAGFile will be set to
* nil.
*/
- (void)setPathAsync:(nullable NSString*)filePath
- (void)setPathAsync:(NSString*)filePath
maxFrameRate:(float)maxFrameRate
completionBlock:(void (^_Nullable)(PAGFile* __nullable))callback;
completionBlock:(void (^)(PAGFile*))callback;

/**
* If set to true, the PAGImageView loads all image frames into the memory, which will significantly
Expand Down Expand Up @@ -162,12 +163,12 @@ PAG_API @interface PAGImageView : UIImageView
* Adds a listener to the set of listeners that are sent events through the life of an animation,
* such as start, repeat, and end. PAGImageView only holds a weak reference to the listener.
*/
- (void)addListener:(nullable id<PAGImageViewListener>)listener;
- (void)addListener:(id<PAGImageViewListener>)listener;

/**
* Removes the specified listener from the set of listeners
*/
- (void)removeListener:(nullable id<PAGImageViewListener>)listener;
- (void)removeListener:(id<PAGImageViewListener>)listener;

/**
* Returns the current frame index the PAGImageView is rendering.
Expand All @@ -188,7 +189,7 @@ PAG_API @interface PAGImageView : UIImageView
/**
* Returns a UIImage capturing the contents of the current PAGImageView.
*/
- (nullable UIImage*)currentImage;
- (UIImage*)currentImage;

/**
* Starts to play the animation from the current position. Calling the play() method when the
Expand Down Expand Up @@ -218,3 +219,5 @@ PAG_API @interface PAGImageView : UIImageView
- (BOOL)flush;

@end

NS_ASSUME_NONNULL_END
Binary file not shown.
Binary file modified framework/libpag.xcframework/ios-arm64/libpag.framework/libpag
Binary file not shown.
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@
#import <UIKit/UIKit.h>
#import "PAGComposition.h"

NS_ASSUME_NONNULL_BEGIN

/**
* PAGDecoder provides a utility to read image frames directly from a PAGComposition, and caches the
* image frames as a sequence file on the disk, which may significantly speed up the reading process
Expand Down Expand Up @@ -84,14 +86,14 @@ PAG_API @interface PAGDecoder : NSObject
* if failed. Note that caller must ensure that the rowBytes stays the same throughout every copying
* call. Otherwise, it may return false.
*/
- (BOOL)copyFrameTo:(void* _Nonnull)pixels rowBytes:(size_t)rowBytes at:(NSInteger)index;
- (BOOL)copyFrameTo:(void*)pixels rowBytes:(size_t)rowBytes at:(NSInteger)index;

/**
* Reads pixels of the image frame at the given index into the specified CVPixelBuffer. Returns
* false if failed. Reading image frames into HardwareBuffer usually has better performance than
* reading into memory.
*/
- (BOOL)readFrame:(NSInteger)index to:(CVPixelBufferRef _Nonnull)pixelBuffer;
- (BOOL)readFrame:(NSInteger)index to:(CVPixelBufferRef)pixelBuffer;

/**
* Returns the image frame at the specified index. Note that this method must be called while the
Expand All @@ -101,3 +103,5 @@ PAG_API @interface PAGDecoder : NSObject
- (nullable UIImage*)frameAtIndex:(NSInteger)index;

@end

NS_ASSUME_NONNULL_END
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@
#import <UIKit/UIKit.h>
#import "PAGComposition.h"

NS_ASSUME_NONNULL_BEGIN

@class PAGImageView;

@protocol PAGImageViewListener <NSObject>
Expand All @@ -28,29 +30,29 @@
* Notifies the beginning of the animation. It can be called from either the UI thread or the thread
* that calls the play method.
*/
- (void)onAnimationStart:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationStart:(PAGImageView*)pagView;

/**
* Notifies the end of the animation. It can only be called from the UI thread.
*/
- (void)onAnimationEnd:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationEnd:(PAGImageView*)pagView;

/**
* Notifies the cancellation of the animation. It can be called from either the UI thread or the
* thread that calls the stop method.
*/
- (void)onAnimationCancel:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationCancel:(PAGImageView*)pagView;

/**
* Notifies the repetition of the animation. It can only be called from the UI thread.
*/
- (void)onAnimationRepeat:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationRepeat:(PAGImageView*)pagView;

/**
* Notifies another frame of the animation has occurred. It may be called from an arbitrary
* thread if the animation is running asynchronously.
*/
- (void)onAnimationUpdate:(PAGImageView* _Nonnull)pagView;
- (void)onAnimationUpdate:(PAGImageView*)pagView;

@end

Expand Down Expand Up @@ -80,14 +82,14 @@ PAG_API @interface PAGImageView : UIImageView
* composition is already added to another PAGImageView, it will be removed from the previous
* PAGImageView.
*/
- (void)setComposition:(nullable PAGComposition*)newComposition;
- (void)setComposition:(PAGComposition*)newComposition;

/**
* Sets a new PAGComposition and the maxFrameRate limit to the PAGImageView. Note: If the
* composition is already added to another PAGImageView, it will be removed from the previous
* PAGImageView.
*/
- (void)setComposition:(nullable PAGComposition*)newComposition maxFrameRate:(float)maxFrameRate;
- (void)setComposition:(PAGComposition*)newComposition maxFrameRate:(float)maxFrameRate;

/**
* Returns the file path set by the setPath() method.
Expand All @@ -98,28 +100,27 @@ PAG_API @interface PAGImageView : UIImageView
* Loads a pag file from the specified path, returns false if the file does not exist, or it is not
* a valid pag file.
*/
- (BOOL)setPath:(nullable NSString*)path;
- (BOOL)setPath:(NSString*)path;
/**
* Loads a pag file from the specified path with the maxFrameRate limit, returns false if the file
* does not exist, or it is not a valid pag file.
*/
- (BOOL)setPath:(nullable NSString*)filePath maxFrameRate:(float)maxFrameRate;
- (BOOL)setPath:(NSString*)filePath maxFrameRate:(float)maxFrameRate;

/**
* Asynchronously load a PAG file from the specific path, a block with PAGFile will be called
* when loading is complete. If loading fails, PAGFile will be set to nil.
*/
- (void)setPathAsync:(nullable NSString*)filePath
completionBlock:(void (^_Nullable)(PAGFile* __nullable))callback;
- (void)setPathAsync:(NSString*)filePath completionBlock:(void (^)(PAGFile*))callback;

/**
* Asynchronously load a PAG file from the specific path with the maxFrameRate limit, a block
* with PAGFile will be called when loading is complete. If loading fails, PAGFile will be set to
* nil.
*/
- (void)setPathAsync:(nullable NSString*)filePath
- (void)setPathAsync:(NSString*)filePath
maxFrameRate:(float)maxFrameRate
completionBlock:(void (^_Nullable)(PAGFile* __nullable))callback;
completionBlock:(void (^)(PAGFile*))callback;

/**
* If set to true, the PAGImageView loads all image frames into the memory, which will significantly
Expand Down Expand Up @@ -162,12 +163,12 @@ PAG_API @interface PAGImageView : UIImageView
* Adds a listener to the set of listeners that are sent events through the life of an animation,
* such as start, repeat, and end. PAGImageView only holds a weak reference to the listener.
*/
- (void)addListener:(nullable id<PAGImageViewListener>)listener;
- (void)addListener:(id<PAGImageViewListener>)listener;

/**
* Removes the specified listener from the set of listeners
*/
- (void)removeListener:(nullable id<PAGImageViewListener>)listener;
- (void)removeListener:(id<PAGImageViewListener>)listener;

/**
* Returns the current frame index the PAGImageView is rendering.
Expand All @@ -188,7 +189,7 @@ PAG_API @interface PAGImageView : UIImageView
/**
* Returns a UIImage capturing the contents of the current PAGImageView.
*/
- (nullable UIImage*)currentImage;
- (UIImage*)currentImage;

/**
* Starts to play the animation from the current position. Calling the play() method when the
Expand Down Expand Up @@ -218,3 +219,5 @@ PAG_API @interface PAGImageView : UIImageView
- (BOOL)flush;

@end

NS_ASSUME_NONNULL_END
Binary file not shown.
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
</data>
<key>Headers/PAGDecoder.h</key>
<data>
UErCrad780sSrXH6rt8Y+aqOsu0=
iycvUyfyMq4r9NcDe4E5rqOmpWo=
</data>
<key>Headers/PAGDiskCache.h</key>
<data>
Expand All @@ -42,7 +42,7 @@
</data>
<key>Headers/PAGImageView.h</key>
<data>
dSSBCVuUA8jQk9L1ZI/bqaB41eA=
drNqDXrTEQFAE1zuEBaV54Ufnyo=
</data>
<key>Headers/PAGLayer.h</key>
<data>
Expand Down Expand Up @@ -102,7 +102,7 @@
</data>
<key>Info.plist</key>
<data>
ZPGKRZIezlFZpxhlUPQBLA+uicI=
UA6V3gQvfRxlDd09oGpqi2FfUTs=
</data>
<key>Modules/module.modulemap</key>
<data>
Expand Down Expand Up @@ -136,7 +136,7 @@
<dict>
<key>hash2</key>
<data>
piLhonsU+oOVsvI9pyBe+vsnc5jhh6X+XpIMyOw6SdQ=
uoP36uOJreBqU7Wzdfvl7iuGt8aqqIbt7MUKsRSfPKE=
</data>
</dict>
<key>Headers/PAGDiskCache.h</key>
Expand Down Expand Up @@ -178,7 +178,7 @@
<dict>
<key>hash2</key>
<data>
dRSN6BDZ76pR1a7UujIT+9b0WkVlOHdvgJdwx6ZvJ1A=
NaHHlhE565SOmyTIPWeOJ11OWAMs3TjF5Mfy7G4kOlU=
</data>
</dict>
<key>Headers/PAGLayer.h</key>
Expand Down
Binary file not shown.
2 changes: 1 addition & 1 deletion libpag.podspec
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Pod::Spec.new do |s|

s.name = 'libpag'
s.version = '4.4.12'
s.version = '4.3.65'
s.ios.deployment_target = '9.0'
s.summary = 'libpag SDK'
s.homepage = 'https://github.com/libpag/libpag-ios'
Expand Down

0 comments on commit 21e17f4

Please sign in to comment.