zoukankan      html  css  js  c++  java
  • Masonry自动布局与UIScrolView适配

    Masonry介绍

    Masonry是一个轻量级的布局框架 拥有自己的描述语法 采用更优雅的链式语法封装自动布局 简洁明了 并具有高可读性 而且同时支持 iOS 和 Max OS X。可以通过cocoapods将其导入。

    Masonry使用

    Masonry属性及其说明

    //左侧
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_left;
    
    //上侧
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_top;
    
    //右侧
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_right;
    
    //下侧
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_bottom;
    
    //首部
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_leading;
    
    //尾部
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_trailing;
    
    //宽度
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_width;
    
    //高度
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_height;
    
    //横向中点
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_centerX;
    
    //纵向中点
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_centerY;
    
    //文本基线
    
    //@property (nonatomic, strong, readonly) MASViewAttribute *mas_baseline;

    其中leading与left trailing与right 在正常情况下是等价的 但是当一些布局是从右至左时(比如阿拉伯文?没有类似的经验) 则会对调 换句话说就是基本可以不理不用 用left和right就好了

    • 首先介绍下UIScrollView的frame与contentsize的区别

    • 重要说明

    (1)UIScrollView的frame与contentsize属性的区分:UIScrollView的frame指的是这个scrollview的可视范围(可看见的区域),contentsize是其滚动范围。

    (2)contentinset(不带*号的一般不是结构体就是枚举),为UIScrollView增加额外的滚动区域。(上,左,下,右)逆时针。contentinset可以使用代码或者是视图控制器进行设置,但两者有区别(注意区分)。

    (3)contentsize属性只能使用代码设置。

    (4)contentoffset是个CGpoint类型的结构体,用来记录ScrollView的滚动位置,即记录着“框”跑到了哪里。知道了这个属性,就知道了其位置,可以通过设置这个属性来控制这个“框”的移动。

    (5)不允许直接修改某个对象内部结构体属性的成员,三个步骤(先拿到值,修改之,再把修改后的值赋回去)。

    (6)增加了额外区域后,contentoffset的原点在哪里?

    • 有助于理解的几个截图

    模型图:

    对比图:

    坐标图:

    MasonryUIScrollView的自动布局:

    • 首先确定UIScrollView的位置:相当于确定UIScrollView的frame
     //UIScrollView滑动界面
        [self.scrollView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.top.mas_equalTo(self.view);
            make.left.equalTo(self.view).offset(0);
            make.right.equalTo(self.view).offset(0);
            make.bottom.mas_equalTo(self.view.mas_bottom).offset(-60);
    
        }];
    • 适配界面1,使界面1的top,left,heightwidth与scrollview对齐,其中在Masonry适配中top,可以与bottom或则height确定View的竖直方位,同理Left可以与right或则width确定水平位置的方位
    //1界面适配
        [self.accountElectricChargeView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.top.mas_equalTo(@0);
            make.left.mas_equalTo(self.scrollView.mas_left);
            make.height.mas_equalTo(self.scrollView.mas_height);
            make.width.mas_equalTo(self.scrollView.mas_width);
        }];
    • 适配界面2:因为是适配水平位置,所以top仍然与scrollView的对齐,left与第一个界面的right对齐,bottom与scrollView或则第一个界面对齐
     //2界面适配
        [self.accountPeakElectricView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.top.mas_equalTo(@0);
            make.left.mas_equalTo(self.accountElectricChargeView.mas_right);
         make.bottom.mas_equalTo(self.scrollView);
    •      make.width.mas_equalTo(self.accountElectricChargeView.mas_width); }];
    • 适配界面3:与界面2同理
     //3界面适配
        [self.accountElectricFactorView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.top.mas_equalTo(@0);
            make.left.mas_equalTo(self.accountPeakElectricView.mas_right);
            make.bottom.mas_equalTo(self.scrollView);
            make.width.mas_equalTo(self.accountElectricChargeView.mas_width);
        }];
    • 最后,使scrollview的right与第三个界面(即最后一个界面)的right对齐。
    [self.scrollView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.right.mas_equalTo(self.accountElectricFactorView.mas_right);
        }];
  • 相关阅读:
    docker重启提示已存在一个容器的问题处理
    conda虚拟环境安装
    dell5460笔记本电脑ubuntu18.04系统音频驱动的安装和使用
    CentOS8的网络管理变化
    jupyter notebook 安装扩展nbextensions
    win10系统systeminfo命令的过滤用法
    《学习scrapy框架爬小说》的进一步完善
    记手机端 下拉加载新数据
    记 页面使用overflow-scroll在iOS上滑动卡顿的问题
    记 判断手机号运营商function
  • 原文地址:https://www.cnblogs.com/luerniu/p/5830560.html
Copyright © 2011-2022 走看看