首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

03_iOS导航栏的正确隐藏方式

简介 在项目中经常碰到首页顶部是无限轮播,需要靠最上面显示.有的设置导航栏为透明等一系列的方法,这个可以借助第三方.或者干脆简单粗暴的直接隐藏掉导航栏.可是push到下一个页面的时候是需要导航栏的,如何做了...第一种做法 注意这里一定要用动画的方式隐藏导航栏,这样在使用滑动返回手势的时候效果最好,和上面动图一致.这样做有一个缺点就是在切换tabBar的时候有一个导航栏向上消失的动画. - (void)viewWillAppear...,实现代理方法,在将要显示控制器中设置导航栏隐藏和显示,使用这种方式不仅完美切合滑动返回手势,同时也解决了切换tabBar的时候,导航栏动态隐藏的问题。...最后要记得在控制器销毁的时候把导航栏的代理设置为nil。...self.navigationController.delegate = self; } #pragma mark - UINavigationControllerDelegate // 将要显示控制器

1.3K20

iOS导航栏切换界面时隐藏和显示

,往往又需要重新显示导航栏,关于这样一种设计苹果并没有给出专门的设置,需要我们自己来做,但在尝试了多种方法之后其实也没有很好的方法,QQ其实做的挺好的,如果你现在动手去尝试一下,会发现它的有无导航栏转换之间有一个渐变的毛玻璃效果...YES,否则显示界面后就会瞬间出现导航栏,而达不到平滑的效果。...这个方法是直接隐藏了整个导航栏,所以如果要保存导航栏的一些返回按钮以及其他自定义的按钮,就需要自己在界面上去模拟添加,如果不想这么麻烦,也可以不隐藏导航栏,而是将导航栏的背景视图设为透明的: [...forBarMetrics:UIBarMetricsDefault]; self.navigationController.navigationBar.shadowImage = [UIImage new]; 但是在切换到要显示导航栏的界面时...结 上面的方法可以在只有导航栏控制器时比较好的操作,虽然不能做到像QQ那么好,但也能用,但如果有Tabbar存在,就会有问题。那如何做到QQ那样的效果呢?

3.9K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    最新iOS设计规范三|3大界面要素:栏(Bars)

    大标题绝对不能与内容竞争,但是在某些应用中,大标题的粗体会帮助人们浏览和搜索时进行快速定位。例如:在选项卡式布局中,大标题有助于说明活动选项卡,并指示用户何时已滚动到顶部。...在iOS 13及更高版本中,默认情况下,大标题导航栏不包含背景材质或阴影。另外,随着页面滑动,大标题要转换为标准标题。 ? 隐藏大标题导航栏的边框。...在iOS 13及更高版本中,可以通过删除导航栏的阴影来隐藏导航栏的底部边框(当滑动内容区域时,边框会自动重新出现)。无边框样式在大标题导航栏中效果很好,因为它增强了标题和内容之间的联系感。...搜索栏可以单独显示,也可以显示在导航栏或内容视图中。当显示在导航栏中时,可以将搜索栏固定在导航栏中,以便始终可以调用。也可以将其折叠,当用户向上滑动时展开显示。...有几种常见的技术可以做到这一点: · 在APP中使用导航栏,该导航栏会自动显示状态栏背景,并确保内容不会显示在状态栏背后 · 在状态栏背后显示自定义图像,如渐变色或纯色 · 在状态栏背后放置模糊的视图

    9.9K10

    iOS系统中导航栏的转场解决方案与最佳实践

    导航栏组件到底怎么了? 经常有人说 iOS 的原生导航栏组件不好使用,抱怨主要集中在导航栏组件的状态管理和控件的布局问题上。...导航栏的样式变化 对于不同 ViewController 之间的导航栏样式变化,大多可以总结为两种情况: 导航栏的显示与否 导航栏的颜色变化 导航栏的显示与否 对于显示与否的问题,可以在上一节提到的两个方法里调用...:animated: 的效果是一样的,直接使用 setNavigationBarHidden: 会造成导航栏转场过程中的闪现、背景错乱等问题,这一现象在使用手势驱动转场的场景中十分常见,所以正确的方式是使用带有...透明样式导航栏的正确设置方法 如果需要一个透明效果的导航栏,可以使用如下代码实现: [self.navigationController.navigationBar setBackgroundImage...导航栏内置组件的布局规范 导航栏里的组件布局在 iOS 11 后发生了改变,原有的一些解决方案已经失效,这些内容不在本篇文章的讨论范围之内,推荐阅读UIBarButtonItem 在 iOS 11 上的改变及应对方案

    2.4K30

    iOS开发UINavigation系列一——导航栏UINavigtionBar

    iOS开发UINavigation系列一——导航栏UINavigtionBar 一、导航栏的使用         在iOS开发中,我们通常会使用导航控制器,导航控制器中封装了一个UINavigationBar...,实际上,我们也可以在不使用导航控制器的前提下,单独使用导航栏,在UINavigationBar中,也有许多我们可以定制的属性,用起来十分方便。...我们也可以设置导航栏的风格属性,从iOS6之后,UINavigationBar默认为半透明的样式,从上面也可以看出,白色的导航栏下面透出些许背景的红色。...三、导航栏常用属性和方法         从上面我们可以看到,iOS6后导航栏默认都是半透明的,我们可以通过下面的bool值来设置这个属性,设置为NO,则导航栏不透明,默认为YES: @property...item的push与pop操作         UINavigationBar上面不只是简单的显示标题,它也将标题进行了堆栈的管理,每一个标题抽象为的对象在iOS系统中是UINavigationItem

    1.2K31

    导航栏还是侧栏?flutter 跨平台适配指南

    了解不同平台的用户体验 Android 平台的导航栏和侧栏 导航栏: 在 Android 平台上,导航栏通常位于屏幕的顶部,用于显示应用的标题和操作按钮。...简洁的界面:导航栏通常只显示标题和少量操作按钮,可以保持界面的简洁性,适合于功能较少的应用。 劣势: 空间有限:导航栏的空间有限,不能同时显示过多的功能或选项。...平台设计规范:某些平台(如 iOS)更倾向于使用导航栏作为主要的导航方式,因此在遵循平台设计规范的情况下,应优先考虑使用导航栏。 何时应该选择侧栏?...CupertinoNavigationBar:用于在 iOS 应用中显示导航栏,与 iOS 设计规范保持一致。 侧栏组件: Drawer:用于显示应用的侧边栏菜单,通常在屏幕左侧打开。...CupertinoDrawer:用于在 iOS 应用中显示侧边栏,与 iOS 设计规范保持一致。

    34410

    iOS 与 Android 的APP 设计差异

    全局导航栏(Android) 对比Apple,设计方法却截然不同。 iOS没有全局导航栏,因此我们不能指望像Android原生控件那样能支持全局返回。...iOS的两种常见导航形式,分段控制和底部标签栏 虽然在两个操作系统中都有类似的功能(切换标签和分段控制,底部导航和标签栏),但导航形式仍然是iOS和Android之间的主要区别之一。...两者之间存在一些客观差异,例如Android中有全局导航栏而在iOS中却没有,以及两者在视觉上的差异。 Apple认为,常用导航入口应该尽可能的外置,一些用户不常用的功能才需要被放进汉堡菜单中。...最麻烦的是涉及到默认控件,比如单选按钮、复选框、tab切换等等,这些控件需要一个定制的视图来实现显示Android上类似iOS的控件或iOS上类似Android的控件。...模态视图又有两种不同类型:具有不同操作内容的模态列表和用户点击“共享”图标后显示的应用列表。在iOS上也能找到类似的组件,但是在设计风格和布局上差异比较大。

    3.5K10

    iOS状态栏使用总结

    目录: 一、状态栏与导航栏 二、设置状态栏显隐与字体样式 三、设置状态栏背景色 四、启动页隐藏状态栏 五、状态栏、导航栏相关的常用宏定义 相关文章:iOS导航栏的使用总结 一、状态栏与导航栏 状态栏...:显示时间、电池等信息 导航栏:显示app页面标题,返回按钮等 iOS7之前:状态栏与导航栏是分开的; iOS7之后:状态栏与导航栏合在一起;导航部分总高度(64)= 状态栏高度(20) +导航栏内容高度...((44) iPhoneX设备出现以后,状态栏的高度变为44,导航栏部分总高度(88) = 状态栏(44) + 导航栏内容高度(44) 二、设置状态栏显隐与字体样式 iOS状态栏可以设置显示和隐藏,也可以设置文字的颜色...代码的位置很重要;在AppDelegate中写入可以设置整个App页面的状态栏样式; 如果需要单独设置其中一个页面隐藏状态栏,需要在进入页面时设置隐藏,退出页面时设置显示,以保证不影响其他页面的状态栏样式...2.分页设置 在info.plist中设置View controller-based status bar appearance属性为YES,状态栏默认显示且字体黑色。

    1.9K30

    iOS开发UINavigation系列四——导航控制器UINavigationController

    /通过一个自定义的导航栏和工具栏创建导航控制器 - (instancetype)initWithNavigationBarClass:(nullable Class)navigationBarClass...//iOS7之后,在导航中右划会进行pop操作,设置这个的enable可以控制设置手势是否失效 @property(nullable, nonatomic, readonly) UIGestureRecognizer... *interactivePopGestureRecognizer; 四、iOS8后导航的新特性 //这个方法是为了iOS方法的命名统一,在导航中,其作用和push一样 - (void)showViewController...) BOOL hidesBarsWhenKeyboardAppears; //屏幕滑动的时候隐藏导航栏,常用于tableView,上滑隐藏导航栏,下滑显示,带动画效果 @property (nonatomic...; //敲击屏幕可以隐藏与显示导航栏 @property (nonatomic, readwrite, assign) BOOL hidesBarsOnTap; //敲击屏幕的手势 @property

    1.8K20

    iOS小技能:适配安全区域距离(safeAreaInsets)

    引言 应用场景1:自定义导航栏内容,导航栏显示公告和标题 应用场景2:自定义视图底部工具栏 应用场景3: 适配上拉加载更多控件 _vcView.tableView.mj_footer.ignoredScrollViewContentInsetBottom...但是如果一个view没有在视图层次结构中或未在屏幕上显示, 则safeAreaInsets为0; 1.1 问题 视图底部工具栏显示到安全区域之外 1.2 判断安全区域距离 #define isIphoneX...; NSLog(@"导航栏高度:%f",navHeight); //获取tabBar的高度 //1.在tabBarController中使用(你的继承自UITabBarController的VC) CGFloat...#define宏定义的代码,其返回值不能被强制转换成可转换的适合的类型。...///*状态栏和导航栏总高度*/ #define kStatusBarHeight (CGFloat)(isIphoneX?

    4.6K30

    iOS 9人机界面指南(一)上篇:UI设计基础 - 腾讯ISUX

    但是,不同于计算机程序中的窗口,iOS窗口没有可见的部分并且不能在屏幕上被移动到另一个位置。很多iOS应用程序只有一个窗口;可以支持外部显示设备器的应用程序可以有不止一个窗口。...iOS能随着尺寸类别和显示环境变化而自动生成不同布局。举个例子,当垂直尺寸从压缩变为常规时,导航栏和工具栏会自动变高。 当你靠尺寸类别来驱动布局变化时,你的应用在任何显示环境时都能显示得很好。...在某些情况下,在一个应用中结合多种导航类型会有很好的效果。例如,对于扁平信息结构中某一分类下的内容,用分层导航的方式来显示可能会更好。...使用导航栏(Navigation Bar)帮助用户轻松访问分层内容。导航栏的标题可以显示用户当前所处的层级,而后退按钮可以回到上一层级。想要了解更多内容,请查看Navigation Bar....分段控件让用户在一屏内就可以查到不同分类的内容,而不需要切换到其他屏幕。 工具栏(Toolbar)。尽管工具栏和导航栏或标签栏相似,但是工具栏不具导航作用。

    1.9K41

    H5如何与IOS和安卓进行交互

    , 代码 /** * @FUNCTION memberRecharge * @params NaviType是否需要显示导航栏 1 不显示 2 显示 3 会员充值(比较特殊的一个) 4 白色有背景...(禁掉系统的导航栏,使用自己的导航栏) * @params NaviIntro 导航栏显示的文字 * @params NaviColor 导航栏的颜色 * @params ArchiveColor...$mount() 页面调用 /** * @FUNCTION memberRecharge * @params NaviType是否需要显示导航栏 1 不显示 2 显示 3 会员充值(比较特殊的一个...) 4 白色有背景(禁掉系统的导航栏,使用自己的导航栏) * @params NaviIntro 导航栏显示的文字 * @params NaviColor 导航栏的颜色 * @params...js方法的前提是你的方法是挂载在window上的,如果没有挂载,就调不起来,所以下面以react框架为例,说一下怎么讲我们方法挂载到window上!

    2K10

    【IOS开发基础系列】Navigation页面导航专题

    : UIBarMetricsDefault]; 2.5 常见开发问题 2.5.1 tableView被导航栏遮挡 IOS开发---菜鸟学习之路--(二十四)-iOS7View被导航栏遮挡问题的解决 http...: YES]; [super pushViewController: viewController animated: animated]; 而Tabbar的显示,则只有在Pop函数调用前执行才真正起作用...: NO]; } return [super popToViewController: viewController animated: animated]; 3 参考链接 自定义iOS 7 导航栏背景...,标题和返回按钮文字颜色 http://blog.csdn.net/mad1989/article/details/41516743 IOS自定义导航栏题目和返回按钮标题 http://blog.csdn.net...tid-180226-page-1.html (good)iOS 7 UITabBar自定义选中图片显示为默认蓝色的Bug http://thierry-xing.iteye.com/blog/2171602

    45520

    iOS 知识小集(Status Bar变换)

    背景 iOS 中经常会有需要在某个界面改变状态栏颜色或者某个界面隐藏状态栏的需求。而改变状态栏颜色和控制状态栏显示和隐藏的API,在iOS 的不同版本中也发生了很多变化。...iOS 7以前 在iOS 7之前,状态栏是不占视图位置的。每个控制器中的根view都是从屏幕的Y轴20px处开始显示的。...iOS 7以前状态栏设置 从API来看,那时候也是支持在代码里修改状态栏的样式以及显示和隐藏的。只是因为状态栏对整个APP的影响不大,所以一般在plist里设置好后,用不着再去修改了。 ?...API iOS 7 ~iOS 9 从iOS 7开始系统风格大变样,图标扁平了,状态栏也不在闹独立了。因为状态栏的会受到导航栏或者View背景色的影响,所以状态栏的风格也需要实时调整了。...效果gif iOS 9 之后 如上面第二张图所示,UIApplication的控制状态栏的方法,在iOS 9之后被弃用了。 所以iOS 9之后尽量使用重写ViewController方法的方式吧。

    1.3K21

    iOS 9人机界面指南(四):UI元素(上) - 腾讯ISUX

    以下有一些方法可以让滚动的内容能正常显示在状态 栏后面: 使用导航控制器(navigation controller)来展示内容。导航控制器自动展示状态栏背景,同时能确保内容视图不会出现在状态栏后面。...千万千万,避免在状态栏后面叠加会分散注意力的内容。尤其是,你不能让用户觉得轻击状态栏之后可以获取内容或激活你的应用中的控件。 隐藏状态栏时请慎重。由于状态栏是透明的,通常情况下不需要隐藏它。...在iOS 8以及之后的版本里,你可以通过UISearchDisplayController简单快捷地把搜索栏放在导航栏中。...如果右侧详情窗格比左侧主窗格窄,对分视图控制器将不能占满整个屏幕,产生视觉不平衡的整体效果。 避免在两侧窗格中都同时展示导航栏。这样会让用户很难分清这两个窗格的从属关系。...但请注意,由于键盘的布局以及输入方法是由用户的系统语言设置决定的,这是你不能控制的。 iOS提供了各种不同的键盘类型,以便用户输入不同类型的文本。

    10.1K51

    最新iOS设计规范八|3大图标和图像规范(Icons and Images)

    Apple产品受版权保护,不能在您的图标或图像中复制。通常,避免显示设备的副本,因为硬件设计会经常更改,并且会使图标显得过时。 不要在整个界面中放置您的应用程序图标。...如果你不提供这些图标,iOS可能会缩小你的主应用程序图标显示在这些位置上。 ? 不要在“设置”图标上添加叠加层或边框。...导航栏和工具栏图标 标签栏图标 主屏幕快速操作图标 在运行iOS12及更早版本的APP中,尽可能使用这些内置图标是个好办法,因为它们对用户来说已经很熟悉了。 按预期使用系统图标。...导航栏和工具栏图标 在导航栏和工具栏中使用以下图标。 注:可以使用文本代替图标来表示导航栏或工具栏中的项目。例如:日历在工具栏中使用“今日”、“日历”和“收件箱”。...还可以使用固定空间元素在导航图标和工具栏图标之间提供填充。 ? ? 标签栏图标 在标签栏中使用以下图标。 ? 主屏幕快速行动图标 在主屏幕快速操作菜单中使用以下图标。 ? ? ?

    3.1K20

    iPhoneX 适配实践

    顶部区域包括导航栏、状态栏或者传感器区域,底部区域包含Tabbar、工具栏或者home键指示器区域。...四、布局适配 1、自定义导航栏 如果你的项目存在导航栏界面push到全屏界面,或者手势滑动做很炫的过场动画,那么你可能会用到自定义导航栏NavigationBar,每个ViewController维护自身的...; 设置该值后也要相应调整下导航栏的布局,之前是在SafeArea之内,现在要改为之外。...可交互的固定组件是不能遮住home键指示器,需要放置在安全区域底部内。...解决方案:系统的UIToolBar会自动扩展背景颜色到底部,可以让Custombar继承UIToolBar,或者直接放置一个ToolBar的在底部当做背景也是可以的。注意高度不能超过48,否则失效。

    3.8K41

    『React Navigation 3x系列教程』之createStackNavigator开发指南

    ,在iOS上是从屏幕的右侧划入,当然你也可以通过配置让StackNavigator支持屏幕从底部滑入的效果。...headerMode: 导航栏的显示模式: screen: 有渐变透明效果, float: 无透明效果, none: 隐藏导航栏。 float: 无透明效果, 默认。...: 定义在iOS上当前页面进入到下一页面的回退标题,可以通过设置null来禁用它; headerTruncatedBackTitle: 当回退标题不能显示的时候显示此属性的标题,比如回退标题太长了; headerBackImage...:React 元素或组件在标题的后退按钮中显示自定义图片。...headerRight: 定义导航栏右边视图; headerLeft: 定义导航栏左边视图; headerStyle: 定义导航栏的样式,比如背景色等; headerTitleStyle: 定义标题的样式

    5K10
    领券