zoukankan      html  css  js  c++  java
  • iOS开发之cell位置contentOffset的用法

    @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);

  • 相关阅读:
    BZOJ5194: [Usaco2018 Feb]Snow Boots(排序&set)(可线段树优化)
    BZOJ5280: [Usaco2018 Open]Milking Order(二分+拓扑)
    BZOJ5281: [Usaco2018 Open]Talent Show(01分数规划&DP)
    BZOJ4837:[Lydsy1704月赛]LRU算法(双指针&模拟)
    【NOIP2013】传染病控制
    bzoj 2754: [SCOI2012]喵星球上的点名
    bzoj 4197: [Noi2015]寿司晚宴
    Codeforces Round #438 B. Race Against Time
    Codeforces Round #438 C. Qualification Rounds
    Codeforces Round #438 D. Huge Strings
  • 原文地址:https://www.cnblogs.com/wcLT/p/4724422.html
Copyright © 2011-2022 走看看