项目作者: jkpang

项目描述 :
iOS与macOS中一款优雅的数字/金额增减动效组件
高级语言: Objective-C
项目地址: git://github.com/jkpang/PPCounter.git


iOS与macOS中一款优雅的数字/金额增减动效控件

iPhone
Mac

  • 支持iOS/macOS双平台(pods版本v0.5.0起支持)
  • 支持UILable/UIButton/自定义文本 控件的数字加减动画;
  • 支持一般文本属性以及富文本属性的字体显示;
  • 支持四种时间曲线函数动画:由慢到快再到慢、由慢到特别快、由快到慢、匀速;
  • 支持自定义的文本格式,例如:数字格式化千分位显示;
  • 支持CocoaPods导入

新建 PP-iOS学习交流群 : 323408051 有关于PP系列封装的问题和iOS技术可以在此群讨论

简书地址

Requirements 要求

  • iOS 7+
  • macOS 10.10+
  • Xcode 8+

Installation 安装

1.手动安装:

下载DEMO后,将子文件夹PPCounter拖入到项目中, 导入头文件 PPCounter.h 开始使用

2.CocoaPods安装:

first
pod 'PPCounter',:git => 'https://github.com/jkpang/PPCounter.git'

then
pod install 或 pod install --no-repo-update

如果发现pod search PPCounter 不是最新版本,在终端执行pod setup命令更新本地spec镜像缓存(时间可能有点长),重新搜索就OK了

Usage 使用方法

1. UILabel

1.1 设置一般字体属性UILabel

  1. ....
  2. [label pp_fromNumber:0 toNumber:100 duration:1.5 animationOptions:PPCounterAnimationOptionCurveEaseOut format:^NSString *(CGFloat number) {
  3. // 此处自由拼接内容
  4. return [NSString stringWithFormat:@"%.2f",number];
  5. } completion:^{
  6. // 完成的回调
  7. }];

1.2 设置富文本字体属性UILabel

  1. ....
  2. [label pp_fromNumber:0 toNumber:100 duration:1.5 animationOptions:PPCounterAnimationOptionCurveEaseOut attributedFormat:^NSAttributedString *(CGFloat number) {
  3. // 此处自由设置富文本属性的内容
  4. NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:@""];
  5. return attributedString;
  6. } completion:^{
  7. // 完成的回调
  8. }];

2. UIButton

2.1 设置一般字体属性UIButton

  1. ....
  2. [button pp_fromNumber:0 toNumber:100 duration:1.5 animationOptions:PPCounterAnimationOptionCurveEaseOut format:^NSString *(CGFloat number) {
  3. // 此处自由拼接内容
  4. return [NSString stringWithFormat:@"%.2f",number];
  5. } completion:^{
  6. // 完成的回调
  7. }];

2.2 设置富文本字体属性UIButton

  1. ....
  2. [button pp_fromNumber:0 toNumber:100 duration:1.5 animationOptions:PPCounterAnimationOptionCurveEaseOut attributedFormat:^NSAttributedString *(CGFloat number) {
  3. // 此处自由设置富文本属性的内容
  4. NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:@""];
  5. return attributedString;
  6. } completion:^{
  7. // 完成的回调
  8. }];

以上就是PPCounter的简单使用方法,更详细的用法请看demo

3, macOS Platform 使用

  1. [[PPCounterEngine counterEngine] fromNumber:0
  2. toNumber:999
  3. duration:2.f
  4. animationOptions:PPCounterAnimationOptionCurveEaseOut
  5. currentNumber:^(CGFloat number) {
  6. // lable控件
  7. self.numberLabel.stringValue = [NSString stringWithFormat:@"%ld",(NSInteger)number];
  8. } completion:^{
  9. // 计数完成的回调
  10. self.numberLabel.textColor = [NSColor redColor];
  11. }];

你的star是我持续更新的动力!

===

CocoaPods更新日志

  • 2017.03.07(tag:0.6.0)—Mac下的定时器由 NSTimer —> dispatch_source_t;
  • 2017.03.07(tag:0.5.0)—支持iOS/MacOS双平台;
  • 2017.01.07(tag:0.2.0)—优化代码命名规范;
  • 2016.10.23(tag:0.1.1)—优化代码结构与调用API方法;
  • 2016.10.19(tag:0.1.0)—初始化到CocoaPods;

我的App <-> My APP

  • PPHub:一个简洁漂亮的 GitHub iOS客户端 <-> A simple and beautiful GitHub iOS client
    App_Store

联系方式:

PP-iOS学习交流群群二维码

许可证

PPCounter 使用 MIT 许可证,详情见 LICENSE 文件。