iOS开发之cell位置contentOffset的用法

本文详细解释了UIScrollView中的关键属性contentSize、contentOffset及contentInset的作用,并通过实例展示了如何使用这些属性来实现scrollView的内容滚动和定位。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@property(nonatomic)         CGPoint                      contentOffset;                  // default CGPointZero

@property(nonatomic)         CGSize                       contentSize;                    // default CGSizeZero

 

 

/* Points. */

struct CGPoint {

  CGFloat x;

  CGFloat y;

};

typedef struct CGPoint CGPoint;

 

/* Sizes. */

struct CGSize {

  CGFloat width;

  CGFloat height;

};

 

由以上代码可知:

contentSize(类型为CGSize,代表尺寸):是scrollview可以滚动的区域,比如frame = (0 ,0 ,320 ,480) contentSize = (320宽 ,960高),代表你的scrollview可以上下滚动,滚动区域为frame大小的两倍。 


contentOffset(类型为CGPoint,代表坐标):是scrollview当前显示区域顶点相对于frame顶点的偏移量,比如上个例子你拉到最下面,contentoffset就是(0 ,480),也就是y偏移了480 

 

contentInset是scrollview的contentview的顶点相对于scrollview的位置,例如你的contentInset = (0 ,100),那么你的contentview就是从scrollview的(0 ,100)开始显示 

 

  cell位置获取方法:CGRect cellRect = [myTable rectForRowAtIndexPath:indexPath];

    可取得cell在tableView中具体位置,以此来进行进一步的计算。如要获取cell在view中的位置,可进行如下计算:

    float upY = myTable.contentOffset.y-cellRect.origin.y;//cell在view中y值

 

    微信中,当用户对某一状态进行评论时,tableView将定位到将要评论的cell的底部,此功能计算如下:

    //keyboardHeight为键盘高度,bgView为评论输入框所在背景视图高度,viewY为cell高度变化后所在view中的位置

    float viewY = self.view.frame.size.height-(keyboardHeight+bgView.frame.size.height);

    float spaceY = (cellRect.origin.y+cellRect.size.height)-(offset.y+viewY);

    //调整tableView的contentOffset值

    myTable.contentOffset = CGPointMake(0, myTable.contentOffset.y+spaceY);

转载于:https://www.cnblogs.com/wcLT/p/4724422.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值