ios UIScrollView滚动视图在视图最上面的时候存在空隙的解决方法教程

54 篇文章 1 订阅
18 篇文章 0 订阅


#前言
这段时间一直在学习英语,所以没时间写文章,学习英语帮助还挺大的,现在看编译器错误不用翻译软件也能有兴趣看完了,简单的能直接看懂.今天要给公司的app的首页重做,因为这个是以后的工作,这2天干活快,就提前把以前程序员首页重做了一下.发现在xib中滚动视图UIScrollView如果放在最上面的话,一定在statusBar下面出现.所以不得不借助代码计算状态栏高度来解决这个问题

先看一下不移动状态栏直接让滚动视图在在最上面的错误结果,分别展示普通屏幕和带刘海屏的:

在这里插入图片描述

看一下想要的结果:

在这里插入图片描述

在xib中布局的时候把内容视图contentView距离滚动视图scrollView的距离连线到代码,通过代码计算出状态栏高度,然后让内容视图距离滚动视图,向上移动状态栏的高度就行了
swift 计算状态栏高度代码,这个代码比宏定义 机型选择 44:20 的要好,因为如果出现以后未来新的机型,不是44或者22,也能算出来

UIApplication.shared.statusBarFrame.height 

oc计算状态栏高度代码

在这里插入代码片

[UIApplication sharedApplication].statusBarFrame.size.height

下面是swift代码中控制器加载以后设置滚动视图的

import UIKit

class HomeVC:  UIViewController{

    @IBOutlet weak var scrollVtop: NSLayoutConstraint!//距离的连线
    override func viewDidLoad() {
        super.viewDidLoad()
        title = "首页上面的"
        // Do any additional setup after loading the view.
        //获取状态栏高度
        let statusHeight = UIApplication.shared.statusBarFrame.height
        
        print("statusHeight=",statusHeight)
        scrollVtop.constant = statusHeight * -1
    }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
iOS中,我们可以使用滚动视图UIScrollView)来创建一个可以进行滚动的内容视图。在该滚动视图中添加按钮,可以通过以下步骤实现: 1. 创建滚动视图对象:使用`UIScrollView`类创建一个滚动视图对象,可以通过代码或者图形化界面编辑器进行创建。 2. 设置滚动范围:通过设置滚动视图的`contentSize`属性,确定滚动内容的大小。内容大小应该大于滚动视图的可见区域,这样才能进行滚动。例如,`scrollView.contentSize = CGSizeMake(320, 600)`。 3. 添加按钮:创建按钮对象,并设置按钮的位置和样式。例如,`UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(50, 50, 100, 50)]`。 4. 将按钮添加到滚动视图中:使用`addSubview`方法将按钮对象添加到滚动视图中。例如,`[scrollView addSubview:button]`。 5. 设置按钮的位置:通过设置按钮的`frame`属性,确定按钮在滚动视图中的位置。需要注意的是,按钮的位置是相对于滚动视图的坐标系的。例如,`button.frame = CGRectMake(50, 50, 100, 50)`。 6. 设置滚动视图的代理:如果需要监听按钮的点击事件,可以将滚动视图的`delegate`属性设置为当前的视图控制器,并实现`UIScrollViewDelegate`协议。例如,`scrollView.delegate = self`。 7. 监听按钮的点击事件:在滚动视图的代理方法中,根据需要实现按钮的点击事件处理逻辑。例如,对于点击事件的处理可以通过`UIButton`的`addTarget:action:forControlEvents:`方法或者手势识别器来完成。 以上就是在iOS中使用滚动视图添加按钮的基本步骤。根据需要,可以根据具体情况进行定制和扩展。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值