iOS翻页视图控制器UIPageViewController的应用(二)

简介: iOS翻页视图控制器UIPageViewController的应用

三、UIPageViewController中方法使用解析


//创建翻页视图控制器对象

- (instancetype)initWithTransitionStyle:(UIPageViewControllerTransitionStyle)style navigationOrientation:(UIPageViewControllerNavigationOrientation)navigationOrientation options:(nullable NSDictionary<NSString *, id> *)options;

上面方法用于创建视图控制器对象,其中UIPageViewControllerTransitionStyle参数设置翻页控制器的风格,枚举如下:


typedef NS_ENUM(NSInteger, UIPageViewControllerTransitionStyle) {

   UIPageViewControllerTransitionStylePageCurl = 0, //类似于书本翻页效果

   UIPageViewControllerTransitionStyleScroll = 1 // 类似于ScrollView的滑动效果

};

如果设置为UIPageViewControllerTransitionStyleCurl,翻页效果如下图所示:


image.png


上面初始化方法中的UIPageViewControllerNavigationOrientation属性设置翻页的方向,枚举如下:


typedef NS_ENUM(NSInteger, UIPageViewControllerNavigationOrientation) {

   UIPageViewControllerNavigationOrientationHorizontal = 0,//水平翻页

   UIPageViewControllerNavigationOrientationVertical = 1//竖直翻页

};

options参数用于设置翻页视图控制器的配置字典,其可以设置的配置键值如下:


//这个键需要设置为UIPageViewControllerOptionSpineLocationKey枚举值对应的NSNumber对象 设置翻页控制器的书轴 后面会介绍

NSString * const UIPageViewControllerOptionSpineLocationKey;

//这个键需要设置为NSNumber类型 设置每页视图的间距 用于滚动视图风格的

NSString * const UIPageViewControllerOptionInterPageSpacingKey;

下面是UIPageViewController的一些常用属性与方法:


//设置数据源

@property (nullable, nonatomic, weak) id <UIPageViewControllerDelegate> delegate;

//设置代理

@property (nullable, nonatomic, weak) id <UIPageViewControllerDataSource> dataSource;

//获取翻页风格

@property (nonatomic, readonly) UIPageViewControllerTransitionStyle transitionStyle;

//获取翻页方向

@property (nonatomic, readonly) UIPageViewControllerNavigationOrientation navigationOrientation;

//获取书轴类型

@property (nonatomic, readonly) UIPageViewControllerSpineLocation spineLocation;

//设置是否双面显示

@property (nonatomic, getter=isDoubleSided) BOOL doubleSided;

//设置要显示的视图控制器

- (void)setViewControllers:(nullable NSArray<UIViewController *> *)viewControllers direction:(UIPageViewControllerNavigationDirection)direction animated:(BOOL)animated completion:(void (^ __nullable)(BOOL finished))completion;

上面只有spineLocation属性有些难于理解,其枚举如下:


typedef NS_ENUM(NSInteger, UIPageViewControllerSpineLocation) {

   //对于SCrollView类型的滑动效果 没有书轴 会返回下面这个枚举值

   UIPageViewControllerSpineLocationNone = 0,

   //以左边或者上边为轴进行翻转 界面同一时间只显示一个View

   UIPageViewControllerSpineLocationMin = 1,  

   //以中间为轴进行翻转 界面同时可以显示两个View

   UIPageViewControllerSpineLocationMid = 2,

   //以下边或者右边为轴进行翻转 界面同一时间只显示一个View

   UIPageViewControllerSpineLocationMax = 3  

};

将上面的示例代码修改几个地方如下:


- (void)viewDidLoad {

   [super viewDidLoad];

   // Do any additional setup after loading the view, typically from a nib.

   _pageViewControl = [[UIPageViewController alloc]initWithTransitionStyle:UIPageViewControllerTransitionStylePageCurl navigationOrientation:UIPageViewControllerNavigationOrientationVertical options:@{UIPageViewControllerOptionSpineLocationKey:@2,UIPageViewControllerOptionInterPageSpacingKey:@10}];

   self.view.backgroundColor = [UIColor greenColor];

   _pageViewControl.view.bounds=self.view.bounds;

   _pageViewControl.dataSource=self;

   _pageViewControl.delegate=self;

   ModelViewController * model = [ModelViewController creatWithIndex:1];

   ModelViewController * model2 = [ModelViewController creatWithIndex:2];

   [_pageViewControl setViewControllers:@[model,model2] direction:UIPageViewControllerNavigationDirectionReverse animated:YES completion:nil];

   _pageViewControl.doubleSided = YES;

   _dataArray = [[NSMutableArray alloc]init];

   [_dataArray addObject:model];

   [self.view addSubview:_pageViewControl.view];

}

- (UIPageViewControllerSpineLocation) pageViewController:(UIPageViewController *)pageViewController spineLocationForInterfaceOrientation:(UIInterfaceOrientation)orientation{

   return UIPageViewControllerSpineLocationMid;

}

运行效果如下图所示:


image.png


四、UIPageViewControllerDataSource中方法解析


//向前翻页展示的ViewController

- (nullable UIViewController *)pageViewController:(UIPageViewController *)pageViewController viewControllerBeforeViewController:(UIViewController *)viewController;

//向后翻页展示的ViewController

- (nullable UIViewController *)pageViewController:(UIPageViewController *)pageViewController viewControllerAfterViewController:(UIViewController *)viewController;

//设置分页控制器的分页点数

- (NSInteger)presentationCountForPageViewController:(UIPageViewController *)pageViewController NS_AVAILABLE_IOS(6_0);

//设置当前分页控制器所高亮的点

- (NSInteger)presentationIndexForPageViewController:(UIPageViewController *)pageViewController NS_AVAILABLE_IOS(6_0);

五、UIPageViewControllerDelegate中方法解析


//翻页视图控制器将要翻页时执行的方法

- (void)pageViewController:(UIPageViewController *)pageViewController willTransitionToViewControllers:(NSArray<UIViewController *> *)pendingViewControllers NS_AVAILABLE_IOS(6_0);

//翻页动画执行完成后回调的方法

- (void)pageViewController:(UIPageViewController *)pageViewController didFinishAnimating:(BOOL)finished previousViewControllers:(NSArray<UIViewController *> *)previousViewControllers transitionCompleted:(BOOL)completed;

//屏幕防线改变时回到的方法,可以通过返回值重设书轴类型枚举

- (UIPageViewControllerSpineLocation)pageViewController:(UIPageViewController *)pageViewController spineLocationForInterfaceOrientation:(UIInterfaceOrientation)orientation;

目录
相关文章
|
2月前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
237 4
|
2月前
|
安全 Swift iOS开发
Swift 与 UIKit 在 iOS 应用界面开发中的关键技术和实践方法
本文深入探讨了 Swift 与 UIKit 在 iOS 应用界面开发中的关键技术和实践方法。Swift 以其简洁、高效和类型安全的特点,结合 UIKit 丰富的组件和功能,为开发者提供了强大的工具。文章从 Swift 的语法优势、类型安全、编程模型以及与 UIKit 的集成,到 UIKit 的主要组件和功能,再到构建界面的实践技巧和实际案例分析,全面介绍了如何利用这些技术创建高质量的用户界面。
41 2
|
2月前
|
JSON 前端开发 API
探索iOS开发之旅:打造你的第一个天气应用
【10月更文挑战第36天】在这篇文章中,我们将踏上一段激动人心的旅程,一起构建属于我们自己的iOS天气应用。通过这个实战项目,你将学习到如何从零开始搭建一个iOS应用,掌握基本的用户界面设计、网络请求处理以及数据解析等核心技能。无论你是编程新手还是希望扩展你的iOS开发技能,这个项目都将为你提供宝贵的实践经验。准备好了吗?让我们开始吧!
|
2月前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户点击按钮时,按钮将从圆形变为椭圆形,颜色从蓝色渐变到绿色;释放按钮时,动画以相反方式恢复。通过UIView的动画方法和弹簧动画效果,实现平滑自然的过渡。
76 1
|
iOS开发 容器
iOS翻页视图控制器UIPageViewController的应用(一)
iOS翻页视图控制器UIPageViewController的应用
330 0
iOS翻页视图控制器UIPageViewController的应用(一)
|
4天前
|
iOS开发 开发者
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
|
2月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
28天前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
121 66
|
14天前
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈