• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - 点击部分 View 时如何真正隐藏和显示标签栏? (没有按钮,但屏幕的任何位置)

[复制链接]
菜鸟教程小白 发表于 2022-12-11 20:29:22 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

override func viewDidLoad() {        

    let tap = UITapGestureRecognizer(target: self, action: #selector(touchHandled))
    view.addGestureRecognizer(tap)


}


@objc func touchHandled() {
    tabBarController?.hideTabBarAnimated(hide: true)
}


extension UITabBarController {
    func hideTabBarAnimated(hide:Bool) {
        UIView.animate(withDuration: 2, animations: {
            if hide {
                self.tabBar.transform = CGAffineTransform(translationX: 0, y: 100)
            } else {
                self.tabBar.transform = CGAffineTransform(translationX: 0, y: -100)
            }
        })
    }

}

我只能隐藏标签栏,但当你再次点击时我无法让它显示。我试图寻找堆栈溢出的答案,但答案似乎只有在您使用按钮或 Storyboard 时才有效。



Best Answer-推荐答案


在类中有一个变量 isTabBarHidden,用于存储 tabBar 是否已被动画隐藏。 (您可以使用 tabBar.isHidden,但是在动画隐藏和显示时会使逻辑复杂一点)

class ViewController {

    var isTabBarHidden = false // set the default value as required

    override func viewDidLoad() {        
        super.viewDidLoad()

        let tap = UITapGestureRecognizer(target: self, action: #selector(touchHandled))
        view.addGestureRecognizer(tap)
    }

    @objc func touchHandled() {
        guard let tabBarControllerFound = tabBarController else {
            return
        }
        tabBarController?.hideTabBarAnimated(hide: !isTabBarHidden)
        isTabBarHidden = !isTabBarHidden
    }

}

关于ios - 点击部分 View 时如何真正隐藏和显示标签栏? (没有按钮,但屏幕的任何位置),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52014063/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap