热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

iOS开发中UIScrollView始终显示滚动条及其相关属性详解

在iOS开发中,`UIScrollView`的滚动条显示与隐藏由两个关键属性控制,默认情况下,滚动条会在滚动时短暂显示,然后自动消失。通过设置`showsHorizontalScrollIndicator`和`showsVerticalScrollIndicator`属性为`YES`或`NO`,可以强制始终显示或隐藏水平和垂直滚动条。此外,还可以通过`indicatorStyle`属性调整滚动条的样式,以适应不同的界面需求。这些属性的灵活运用能够显著提升用户体验。

一.UIScrollView显示或者隐藏滚动条, 默认有两个属性

@property(nonatomic)         BOOL                         showsHorizontalScrollIndicator; // default YES. show indicator while we are tracking. fades out after tracking

@property(nonatomic)         BOOL                         showsVerticalScrollIndicator;   // default YES. show indicator while we are tracking. fades out after tracking

这两个属性默认是YES, 显示水平和垂直滚动条, 只有当我们滚动的时候显示,当我们不滚动时,慢慢淡出


二.UIScrollView滚动条的样式, 默认有三个样式

@property(nonatomic)         UIScrollViewIndicatorStyle   indicatorStyle;                 // default is UIScrollViewIndicatorStyleDefault

typedef NS_ENUM(NSInteger, UIScrollViewIndicatorStyle) {    UIScrollViewIndicatorStyleDefault,     // black with white border. good against any background    UIScrollViewIndicatorStyleBlack,       // black only. smaller. good against a white background    UIScrollViewIndicatorStyleWhite        // white only. smaller. good against a black background};

这个属性默认是 UIScrollViewIndicatorStyleDefault, 第二个属性UIScrollViewIndicatorStyleBlack 滚动条是黑色, 第三个属性UIScrollViewIndicatorStyleWhite 滚动条是白色

三.UIScrollView滚动条的偏移量

@property(nonatomic)         UIEdgeInsets                 scrollIndicatorInsets;          // default is UIEdgeInsetsZero. adjust indicators inside of insets

这个属性默认是UIEdgeInsetsZero, 我们可以自己设置偏移量


四.UIScrollView滚动条一直显示

1.我们知道滚动条是一个UIImageView, 滚动条隐藏是因为设置了alpha属性为0, 所有我们写一个UIImageView的分类

#define noDisableVerticalScrollTag 836913
#define noDisableHorizontalScrollTag 836914

@implementation UIImageView (WLScrollView)

- (void)setAlpha:(CGFloat)alpha
{

if (self.superview.tag == noDisableVerticalScrollTag) {
if (alpha == 0 && self.autoresizingMask == UIViewAutoresizingFlexibleLeftMargin) {
if (self.frame.size.width <10 && self.frame.size.height > self.frame.size.width) {
UIScrollView *sc = (UIScrollView*)self.superview;
if (sc.frame.size.height return;
}
}
}
}

if (self.superview.tag == noDisableHorizontalScrollTag) {
if (alpha == 0 && self.autoresizingMask == UIViewAutoresizingFlexibleTopMargin) {
if (self.frame.size.height <10 && self.frame.size.height UIScrollView *sc = (UIScrollView*)self.superview;
if (sc.frame.size.width return;
}
}
}
}

[super setAlpha:alpha];
}
@end

2.写完分类之后, 我们在初始化 UIScrollView的时候设置UIScrollView的tag为836913

3.要在UIScrollView数据绑定之后, 调用以下方法

- (void)flashScrollIndicators;             // displays the scroll indicators for a short time. This should be done whenever you bring the scroll view to front.

即调用以下方法

[scrollView reloadData];
[scrollView flashScrollIndicators];



推荐阅读
author-avatar
dotagod12
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有