iOS UIScrollView

UIScrollView 是可以滚动的View  UIview是不可以滚动的,但是他的子类UIScrollView拓展了滚动方面的功能

UIScrollView是所有滚动视图的基类,UITableView,UItextView等视图都集成与该类

使用场景:一个屏幕显示不了太大的图片;内容太多;滚动头条(图片);相册等

UIScrollView的核心功能

UIScrollView主要专长与两个方面:

1.滚动:contentSize大于frame.size 的时候,能够滚动

2.缩放:自带缩放,可以指定缩放倍数

[1]UIScrollView滚动相关属性

1.contentSize 定义内容区域大小,决定是否能够滚动

2.contentOffset 视图左上角距离坐标原点的偏移量

3.scrollsToTop  滑动到顶部(点击状态条的时候,也就是屏幕最上边)

4.pagingEnabled  是否整平滚动

5.bounces  边界是否回弹

6.scorllEnabled 是否能够滚动

7.showHorizontalScrolllndicator  控制是否显示水平方向的滚动条

8.showVerticalScrollindicator 控制是否显示垂直方向的滚动条

9.alwaysBounceVertical 控制垂直方向遇到边框是否反弹

10.alwaysBounceHorizontal 控制水平方向遇到的边框是否反弹

[2]UIScrollView缩放相关属性

1.minimumZoomScale 缩小的最小比例

2.maximumZoomScale 放的的最大比例

3.zoomScale 设置变化比例

4.zooming 判断是否正在进行缩放的反弹

5.bouncesZoom 控制缩放的时候是否反弹

注意:要实现缩放,还需要实现delegate, 指定缩放的视图是谁

[3]UIScrollView滚动代理方法

先设置代理

self.myview.scrollV.delegate = self;

1.返回要缩放的视图

- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView

{

return self.myview.imV;

}

//2.只要视图偏移发生变化,就触发这个方法

- (void)scrollViewDidScroll:(UIScrollView *)scrollView

{

//    NSLog(@"发生了什么事");

}

- (void)didReceiveMemoryWarning

{

[super didReceiveMemoryWarning];

// Dispose of any resources that can be recreated.

}

//3.将要拖拽的时候,触发这个方法

- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView

{

NSLog(@"what‘s happen???");

}

//4.拖拽结束时,触发这个方法

-(void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate

{

NSLog(@"结束了吗");

}

//5.拖拽完成后减速的时,触发这个方法

-(void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView

{

NSLog(@"慢点");

}

//6.减速结束时,触发这个方法

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView

{

NSLog(@"怎么停了呢");

}

//7.当缩放的时候,触发这个方法

- (void)scrollViewDidZoom:(UIScrollView *)scrollView NS_AVAILABLE_IOS(3_2)

{

NSLog(@"大了.小了");

}

在.h中声明属性

//滚动视图

@property(nonatomic,retain)UIScrollView*scrollVlV;

//传里一个图片

UIImage *image = [UIImage imageNamed:@"s.png"];

//滚动视图

self.scrollV = [[UIScrollView alloc] init];

self.scrollV.frame = [UIScreen mainScreen] .bounds;

//内容尺寸

self.scrollV.contentSize = image.size;

//是否有弹动效果

self.scrollV.bounces = NO;

//显示内容坐标

self.scrollV.contentOffset = CGPointMake(900, 700);

//点击状态栏置顶

self.scrollV.scrollsToTop = YES;

//能否滚动

self.scrollV.scrollEnabled = YES;

//滚动条,竖向显示

self.scrollV.showsHorizontalScrollIndicator = YES;

//滚动条,横向显示

self.scrollV.showsVerticalScrollIndicator = YES;

//分页滑动(手在上面滑得时候,图片跟着滑动到下一页)如果不设置默认是no

self.scrollView.pagingEnabled = YES;

//如果内容小于bounds,也能有弹动效果

self.scrollV.alwaysBounceHorizontal = YES;

self.scrollV.alwaysBounceVertical = NO;

时间: 2024-10-12 12:24:45

iOS UIScrollView的相关文章

iOS: UIScrollView pauses NSTimer while scrolling

StackOverflow http://stackoverflow.com/a/7059499 Question:I have a UIScrollView that has a series of labels which are rapidly updating numbers (every .06 seconds). While the scroll view is moving, however, the NSTimer is paused and does not continue

IOS UIScrollView详解 & 图片缩放功能

一 UIScrollView 简介 UIScrollView是能滚动的视图控件,可以通过滚动的方式来展示类容. 二 UIScrollView常见属性 //设置UIScrollView滚动的位置 @property(nonatomic) CGPoint contentOffset;  //设置UIScrollView内容的尺寸,滚动范围 @property(nonatomic) CGSize contentSize;  //设置UIScrollView的4周增加额外的滚动区域 @property(

iOS UIScrollView 你可能不知道的奇技淫巧

iOS 的 UIScrollView 可以说是十分强大,巧妙地运用它可以得到一些意想不到的效果.本文将举几个 ScrollView 不常见运用的例子. 自带信息应用 这个界面既可以上下卷动,也可以左右滑动拉出发送时间. P.S. 气死宝宝了,我做了一组精美的 gif,但是大小都超出简书限制…..无语,大家就脑补一下效果吧. 这个效果大体看一下就非常像一个很大的 ScrollView,可以四个方向都能滑动.但是 UITableView 只能上下滚动,硬要修改那就是大手术,不推荐这样做.因此我想到的

IOS UIScrollView + UIButton 实现页面和顶部标签页水平滚动效果

很长一段时间没有写博客了,最近在学习iOS开发,看了不少的代码,自己用UIScrollView和UIButton实现了水平滚动的效果,有点类似于今日头条的主界面框架,效果如下: 代码如下: MyScrollView.h #import <UIKit/UIKit.h> #import "MySegementView.h" @interface MyScrollView : UIView<UIScrollViewDelegate> - (instancetype)

iOS UIScrollView 的基本用法

滚视图的用途很普遍,掌握一些基本用法是必须的,以下是一些基本的用法: #import <UIKit/UIKit.h> //宏定义 #define Width 300 #define Height 300 #define X 60 #define Y 100 @interface ViewController : UIViewController<UIScrollViewAccessibilityDelegate> @property(strong,nonatomic) UIScro

IOS UIScrollView中的内容不显示

下午的时候发现一个xib页面在4s中显示不全,于是开始添加滚动条,话说也是第一次添加,各种不熟练,结果添加完发现内容不显示,然后各种找资料各种测试,最终发现我把UIScrollview中作为content的View的透明度设为了0. 为什么要设为0呢?因为往content中添加控件的时候添加进去就一下看不见了,以为是被遮挡了,于是就把这个conten的透明度设为了0,其实不是遮挡,是因为在ScrollView中Conten只设置边距约束的话,他的大小就变为了0,设了大小之后就忘记透明度的事了.

iOS -- UIScrollView的基本属性(contentSize, contentInset, contentOffset)的用法

#import "ViewController.h"@interface ViewController ()@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;@property (weak, nonatomic) IBOutlet UIImageView *minionView;- (IBAction)scroll;@end@implementation ViewController- (void)viewDid

iOS— UIScrollView和 UIPageControl之间的那些事

本代码主要实现在固定的位置滑动图片可以切换. 目录图如下: ViewController.h #import <UIKit/UIKit.h> // 通过宏定义定义宽和高 #define WIDTH self.view.frame.size.width #define HEIGHT self.view.frame.size.height @interface ViewController : UIViewController<UIScrollViewDelegate> @proper

[iOS]UIScrollView左右拨动,第二页宽度只有一半问题

用UIScrollView动态加入新View,而这个View是Xib方式创建,如果设置view的frame,这个view的宽度却只有设置的一半,很奇怪.于是我只设置view的frame的x值,不设置整改frame,包括宽高度都不重新设置,只是frame.x改变,那么就得到了理想的效果.

iOS -- UIScrollView Delegate 代理

#import "MJViewController.h"@interface MJViewController () <UIScrollViewDelegate>@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;@property (weak, nonatomic) IBOutlet UIImageView *minionView;@end@implementation MJViewControlle