iOS 修改UIPageControl样式

注:由于iOS13 系统对一些私有属性的限制,以下的方式不能保证正确性。在iOS13 系统下,UISearchBar 中的视图层级已经更换,UITextField 已经可以外部可用;UITextField 的 _placeholderLabel 成员变量的类型已经不是 UILabel,以往的设置方法已经不能使用。类似的更换非常多,大家还是谨慎使用私有方式进行设置,因此私有 api 具有上架风险,另外就是系统并不会向下兼容地更新。


由于系统并未提供相应的属性和方法让我们修改样式,我们最多只能修改颜色

// 修改颜色
@property(nullable, nonatomic,strong) UIColor *pageIndicatorTintColor;
@property(nullable, nonatomic,strong) UIColor *currentPageIndicatorTintColor;

当我们需要更换样式时,则显得很困难,我们只可能通过KVC间接修改对应的值,前提是系统有相应的成员变量,另外系统可能更换成员变量,这种方式不是很妥当


解决方案

1、寻找成员变量

使用运行时获取到UIPageControl的成员变量

unsigned int count;
Ivar* ivars = class_copyIvarList([UIPageControl class], &count);
for (int i=0; i<count; i++) {
    Ivar ivar = ivars[i];
    NSString* name = [NSString stringWithUTF8String:ivar_getName(ivar)];    // 名称
    NSString* type = [NSString stringWithUTF8String:ivar_getTypeEncoding(ivar)];     // 类型
    NSLog(@"成员变量:%@ -> 类型:%@",name,type);
}

结果:
结果

我们注意到有两个比变量 _currentPageImage 和 _pageImage ,这两个就是我们需要更改的样式,分别对应选中和未选中的样式

2、KVC方式修改

KVC可以修改对象的属性、成员变量,包括私有成员变量

[self.pageControl setValue:[UIImage imageNamed:@"selected"] forKeyPath:@"_currentPageImage"];
[self.pageControl setValue:[UIImage imageNamed:@"normal"] forKeyPath:@"_pageImage"];

3、结果
结果


常见的还是有修改UITextField的_placeholderLabel样式,同样方法,想了解运行时知识的小伙伴的点击这里,运行时的相关应用可以看这里,还有这里


除了上述的 间接的、曲折的修改样式的方法,如果想实现更为优雅或者更为酷炫的样式的话,完全可以自定义控件,掌控性更好,只是稍微麻烦一点而已


补充:

笔者觉得替换为图片时,两个控件的间距太大,试图调整之间的间距,发现系统无法更改其位置和大小,替换的读者需要注意一下,或者有改变位置的方法,希望留言

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS中,要实现仿今日头条滑块滑动效果,可以借助UIKit框架中的UIScrollView以及UICollectionView来实现。 首先,在界面中添加一个UIScrollView,设置其frame为所需大小,并将其contentSize设置为所有滑块所占的总宽度。如果滑块数目较多,可以使用UICollectionView来更方便地布局和管理滑块。 接下来,可以使用UIPageControl来显示当前滑块的页数,通过与UIScrollView的滑动距离进行关联,使UIPageControl随着滑块的滑动而改变页数。可以通过UIScrollViewDelegate的方法scrollViewDidScroll来实现这一功能,根据当前的contentOffset来计算并更新UIPageControl当前页数。 另外,要实现滑块的点击切换功能,可以使用UITapGestureRecognizer来监听滑块的点击事件。当检测到点击时,通过计算点击点的位置来判断点击的是哪个滑块,并使用UIScrollView的方法scrollRectToVisible来将该滑块滑动到可见区域。 为了增强滑块的滑动体验,可以结合UIView动画来实现平滑滑动的效果。使用UIView的方法animateWithDuration:animations:completion:来执行滑块的滑动动画,通过改变UIScrollView的contentOffset来实现滑块的平滑滑动。 此外,还可以添加一些其他效果来增强用户体验,例如滑块滑动到边缘时的弹性效果、滑块的缩放效果等。 总而言之,要实现iOS仿今日头条滑块滑动效果,需要借助UIScrollView或UICollectionView来布局和管理滑块,结合UIPageControl、UITapGestureRecognizer和UIView动画来实现滑块的滑动、点击和平滑滑动效果,并可以添加一些其他效果来增强用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值