iOS高级控件之ScrollView分析(一)

今天学习了scrollView,其实上也挺简单清晰的,下面我带大家一起来使用这个scrollview这个控件的相关属性操作。

首先新建一个single项目,然后再storyboard中加入scrollview,并在ViewController中将属性进行连接(记得是IBOutlet)
这里写图片描述

1.创建一个imageView
1.1 创建UIImage

UIImage *image = [UIImage imageNamed:@"001.jpeg"];
UIImageView *_imageview = [[UIImageView alloc] initWithImage:image];
[_scrollView addSubview:_imageview];

2.设置图片视图滚动属性

[_scrollView setContentSize:image.size];
//拖动后距离边框的距离
UIEdgeInsets edge = UIEdgeInsetsMake(10.0,10.0, 10.0, 10.0);
[_scrollView setContentInset:edge];
//设置背景的颜色
[_scrollView setBackgroundColor:[UIColor grayColor]];

3.其他属性(弹性、滚动、水平滚动条、竖直滚动条)

//3.1 是否有弹性
[_scrollView setBounces:YES];//默认yes下同
//3.2 是否能滚动
[_scrollView setScrollEnabled:YES];//默认yes下同
//3.3是否有水平滚动条
[_scrollView setShowsHorizontalScrollIndicator:YES];
//3.4是否有竖直滚动条
[_scrollView setShowsVerticalScrollIndicator:YES];

4.缩放效果,如果亲们需要实现缩放,那么就需要一个代理协议,在ViewController.h中添加一个协议

@interface ViewController : UIViewController <UIScrollViewDelegate>

同时添加缩放滚动的代理方法

-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{ 
// 缩放时要换个图象的话
NSString *imageFile = [NSString stringWithFormat:@"03d.jpeg",arc4random_uniform(10)+1];
UIImage *image = [UIImage imageNamed:imageFile];
[_imageview setImage:image];

return _imageview;
}

这是在viewDidload中可以加入

[_scrollView setMinimumZoomScale:0.2];
[_scrollView setMaximumZoomScale:2.0];
//设置滚动视图代理
[_scrollView setDelegate:self];

5.通过按钮button实现移动图片

5.1加入四个button,设置tag分别为0,1,2,3,方便使用管理
这里写图片描述

同时将每一个按钮都分别于实现方法进行连接。

5.2 分别设置每一个按钮移动的距离
这里写图片描述

5.3但是为了防止出现无限的移动,甚至是移除了视线,那就不好咯~所以我们可以设置一个判断,用来规范最多能够移动多少。
这里写图片描述

5.4当然这样移动还是有点太生硬,我们不妨加一些动画效果

  //动画效果
  [UIView animateWithDuration:0.3f animations:^{
  //修改图像偏移位置
 [_scrollView setContentOffset:ofset];
    }];

6.ScrollView总结1:

  • CGSize contentSize:设置UIScrollView的滚动范围 CGPoint

  • contentOffset:UIScrollView当前滚动的位置

  • UIEdgeInsets contentInset:增加滚动视图四周的增加滚动范围

    这里写图片描述

注意区分contentSize和contentOffset以及contentInset的坐标系位置,如上图我相信可以很好的帮助大家区分。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 UIScrollView 上添加手势识别器时,有可能会出现手势冲突的情况。这通常是由于 UIScrollView 自身的手势识别器和添加的手势识别器之间的冲突引起的。 要解决这个问题,有几种可能的方法: 1. 禁用 UIScrollView 的手势识别器。这可以通过将 UIScrollView 的属性 `canCancelContentTouches` 和 `delaysContentTouches` 设置为 `NO` 来实现。但是,这样会使 UIScrollView 的滚动功能也被禁用,因此在某些情况下可能并不可取。 2. 使用手势识别器代理方法来控制手势冲突。在手势识别器代理方法 `gestureRecognizer:shouldRecognizeSimultaneouslyWithGestureRecognizer:` 中,可以根据需要返回 `YES` 或 `NO`,以允许或禁止多个手势识别器同时识别手势。 3. 将手势识别器添加到 UIScrollView 的子视图中,而不是直接添加到 UIScrollView 上。这样,手势识别器就不会与 UIScrollView 的手势识别器冲突了。 下面是一个示例代码,演示了如何在 UIScrollView 上添加一个 UISwipeGestureRecognizer 手势识别器,并处理手势冲突的情况: ```objc // 创建一个 UISwipeGestureRecognizer 手势识别器 UISwipeGestureRecognizer *swipeGestureRecognizer = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(handleSwipe:)]; // 设置手势方向 swipeGestureRecognizer.direction = UISwipeGestureRecognizerDirectionLeft; // 将手势识别器添加到 UIScrollView 上 [scrollView addGestureRecognizer:swipeGestureRecognizer]; // 实现手势识别器代理方法,处理手势冲突 - (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer { if ([gestureRecognizer isKindOfClass:[UISwipeGestureRecognizer class]] && [otherGestureRecognizer.view isKindOfClass:[UIScrollView class]]) { return NO; // 禁止 UISwipeGestureRecognizer 和 UIScrollView 同时识别手势 } return YES; } // 处理 UISwipeGestureRecognizer 手势 - (void)handleSwipe:(UISwipeGestureRecognizer *)gestureRecognizer { // 处理手势事件 } ``` 希望这些提示可以帮助你解决 UIScrollView 上的手势冲突问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值