用Xamarin.Forms让iOS 11变得更容易

简介: iOS 11引入了一些您可能想要利用的新的视觉设计更新,包括安全区域布局指南和大型标题。 对于Xamarin.iOS开发人员,我们最近发布了一个iOS 11指南,用于更新您的Xamarin.iOS应用程序和安全区域和大型文章的文章。

iOS 11引入了一些您可能想要利用的新的视觉设计更新,包括安全区域布局指南和大型标题。 对于Xamarin.iOS开发人员,我们最近发布了一个iOS 11指南,用于更新您的Xamarin.iOS应用程序和安全区域和大型文章的文章。 当然,由于Xamarin.Forms是一个运行在Xamarin.iOS之上的图层,所有这些功能都可以立即使用!

在这篇文章中,我将向您展示如何进一步使Xamarin.Forms直接使用这些特性。

使用SafeArea布局

为了确保您的内容出现在设备屏幕的可见区域,特别是为了避免在iPhone X上运行横向时的“缺口”,您将需要利用iOS 11定义的安全区域布局指南。 我们最近写了关于在创建自动布局约束时如何在Xamarin.iOS中使用它。

和往常一样,在Xamarin.Forms中,您可以访问Xamarin.iOS平台代码来获取对这些值的引用并相应地更新您的视图。

但是我们想让你更容易 在2.4.0 Service Release 4中,我们介绍了一个特定于平台的页面,以便使用安全区域布局指南在页面中创建适当的插页。 要选择,将其添加到您的ContentPage构造函数:

点击(此处)折叠或打开   

  1. using Xamarin.Forms.PlatformConfiguration.iOSSpecific;
  2. using Xamarin.Forms;
  3.  
  4. namespace iPhoneX
  5. {
  6.     public partial class ItemsPage : ContentPage
  7.     {
  8.         public ItemsPage()
  9.         {
  10.             InitializeComponent();
  11.  
  12.             OnXamarin.Forms.PlatformConfiguration.iOS>().SetUseSafeArea(true);
  13.         }
  14.     }
  15. }


或者在XAML中:

点击(此处)折叠或打开

  1. ?xml version="1.0" encoding="UTF-8"?>
  2. ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
  3.     xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
  4.     xmlns:ios="clr-namespace:Xamarin.Forms.PlatformConfiguration.iOSSpecific;assembly=Xamarin.Forms.Core"
  5.     ios:Page.UseSafeArea="true" >


在iOS 11及更高版本中,Apple定义的安全区域边界将用于为页面布局的内容设置填充。 请注意,这将覆盖您之前可能设置的填充值。 在需要的每个页面上启用此特定平台。

Xamarin.Forms为插入值提供了一些合理的默认值,但是如果你想要更精细的控制,你应该在构造函数中自己设置填充,或者从SafeAreaInsets()中检索厚度值,并调整值以设置视图的填充满足 您在OnAppearing方法中的需求。

点击(此处)折叠或打开

  1. protected override void OnAppearing()
  2. {
  3.     base.OnAppearing();
  4.  
  5.     var safeInsets = OnXamarin.Forms.PlatformConfiguration.iOS>().SafeAreaInsets();
  6.     safeInsets.Left = 24;
  7.     this.Padding = safeInsets;
  8. }


大标题

部分新的iOS 11更新支持在导航栏中显示更大的标题显示。 与安全区域一样,您现在可以使用特定平台来选择此视觉设计模式。 启用时,通常出现在导航栏中央的标题将显示为左对齐,当然也会更大。 横向标题将返回到中心,以优化内容可见的视图。

第一步是在NavigationPage或ContentPage上设置标题首选项。

点击(此处)折叠或打开

  1. OnXamarin.Forms.PlatformConfiguration.iOS>().SetPrefersLargeTitles(true);

现在,该导航页面中的所有页面都将显示较大的标题。 要在ContentPage级别上进行控制,您可以在此设置首选项。 在这个片段中,首选项设置为从不使用大标题:

点击(此处)折叠或打开

  1. public partial class ItemsPage : ContentPage
  2. {
  3.     public ItemsPage()
  4.     {
  5.         InitializeComponent();
  6.         OnXamarin.Forms.PlatformConfiguration.iOS>().SetLargeTitleDisplay(LargeTitleDisplayMode.Never);
  7.     }
  8.     ...
  9. }


SetLargeTitleDisplay方法有三个选项:

  • 总是
  • 自动
  • 决不

永远不会清楚。 “自动”是默认值,意味着行为从导航堆栈中的上一页继承。

网络预览今天可用
这些特定平台可以通过网络预览来使用。 访问我们的GitHub发布页面来下载NuGet包。 我们正在积极测试这些新平台的具体内容并提供反馈。 如果没有必要进行更改,我们会像NuGet一样推广这个版本。

目录
相关文章
|
Android开发 iOS开发
张高兴的 Xamarin.Forms 开发笔记:为 Android 与 iOS 引入 UWP 风格的汉堡菜单 ( MasterDetailPage )
  所谓 UWP 样式的汉堡菜单,我曾在“张高兴的 UWP 开发笔记:汉堡菜单进阶”里说过,也就是使用 Segoe MDL2 Assets 字体作为左侧 Icon,并且左侧使用填充颜色的矩形用来表示 ListView 的选中。
1347 0
|
11天前
|
iOS开发 开发者
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
104 67
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
|
2月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
1月前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
127 66
|
22天前
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
|
1月前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
150 3
|
1月前
|
Java 调度 Android开发
安卓与iOS开发中的线程管理差异解析
在移动应用开发的广阔天地中,安卓和iOS两大平台各自拥有独特的魅力。如同东西方文化的差异,它们在处理多线程任务时也展现出不同的哲学。本文将带你穿梭于这两个平台之间,比较它们在线程管理上的核心理念、实现方式及性能考量,助你成为跨平台的编程高手。
|
2月前
|
存储 前端开发 Swift
探索iOS开发:从新手到专家的旅程
本文将带您领略iOS开发的奇妙之旅,从基础概念的理解到高级技巧的掌握,逐步深入iOS的世界。文章不仅分享技术知识,还鼓励读者在编程之路上保持好奇心和创新精神,实现个人成长与技术突破。
|
2月前
|
安全 IDE Swift
探索iOS开发之旅:从初学者到专家
在这篇文章中,我们将一起踏上iOS开发的旅程,从基础概念的理解到深入掌握核心技术。无论你是编程新手还是希望提升技能的开发者,这里都有你需要的指南和启示。我们将通过实际案例和代码示例,展示如何构建一个功能齐全的iOS应用。准备好了吗?让我们一起开始吧!
|
2月前
|
安全 Swift iOS开发
Swift 与 UIKit 在 iOS 应用界面开发中的关键技术和实践方法
本文深入探讨了 Swift 与 UIKit 在 iOS 应用界面开发中的关键技术和实践方法。Swift 以其简洁、高效和类型安全的特点,结合 UIKit 丰富的组件和功能,为开发者提供了强大的工具。文章从 Swift 的语法优势、类型安全、编程模型以及与 UIKit 的集成,到 UIKit 的主要组件和功能,再到构建界面的实践技巧和实际案例分析,全面介绍了如何利用这些技术创建高质量的用户界面。
48 2

热门文章

最新文章