- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我对 iOS 的安全区域使用有疑问。
我通过 RelativeLayout
使用背景图片,并在此背景图片上显示表单。我在表单的容器上为 iOS 使用 margin
:这工作正常,但在 iPhone X 上的渲染不是很好。
<RelativeLayout>
<Image Source="background.jpg" Opacity="0.75"
Aspect="AspectFill"
RelativeLayout.WidthConstraint =
"{ConstraintExpression Type=RelativeToParent, Property=Width}"
RelativeLayout.HeightConstraint =
"{ConstraintExpression Type=RelativeToParent, Property=Height}" />
<ScrollView RelativeLayout.WidthConstraint =
"{ConstraintExpression Type=RelativeToParent, Property=Width}"
RelativeLayout.HeightConstraint =
"{ConstraintExpression Type=RelativeToParent, Property=Height}">
<ScrollView.Margin>
<OnPlatform x:TypeArguments="Thickness">
<On Platform="iOS" Value="0, 20, 0, 0" />
</OnPlatform>
</ScrollView.Margin>
<StackLayout>
<!-- Header -->
<StackLayout VerticalOptions="Start">
<fnc:HunterHeader />
</StackLayout>
<!-- Form -->
<StackLayout VerticalOptions="CenterAndExpand"
Spacing="6" Margin="20">
<!-- ... -->
</StackLayout>
</StackLayout>
</RelativeLayout>
所以我尝试将 UseSafeArea
设置为 true,但我得到了顶部和底部边距。
是否可以解决这个问题,并结合 UseSafeArea 和背景图像?或者有没有办法只为 iPhone X 添加特定的边距?
最佳答案
安全区域可以设置在具体的控件上,而不是整个页面。例如,安全区域值可以设置为 ScrollView
的边距或填充。 .还需要考虑方向变化(如果您的应用支持它们)。
XAML
<RelativeLayout>
<Image Aspect="AspectFill" Source="background.png"
RelativeLayout.WidthConstraint = "{ConstraintExpression Type=RelativeToParent, Property=Width}"
RelativeLayout.HeightConstraint = "{ConstraintExpression Type=RelativeToParent, Property=Height}" />
<ScrollView x:Name="scrollView"
RelativeLayout.WidthConstraint = "{ConstraintExpression Type=RelativeToParent, Property=Width}"
RelativeLayout.HeightConstraint = "{ConstraintExpression Type=RelativeToParent, Property=Height}">
<StackLayout Margin="20, 0" Spacing="20">
<!-- Header -->
<StackLayout>
<BoxView BackgroundColor="Black" HeightRequest="50" />
</StackLayout>
<!-- Form -->
<StackLayout Spacing="20">
<BoxView BackgroundColor="White" HeightRequest="150" />
<BoxView BackgroundColor="White" HeightRequest="150" />
<BoxView BackgroundColor="White" HeightRequest="150" />
<BoxView BackgroundColor="White" HeightRequest="150" />
<BoxView BackgroundColor="White" HeightRequest="150" />
<BoxView BackgroundColor="White" HeightRequest="150" />
</StackLayout>
</StackLayout>
</ScrollView>
</RelativeLayout>
代码隐藏
private double width = 0;
private double height = 0;
private bool safeAreaSetInitially;
protected override void OnAppearing()
{
base.OnAppearing();
if (!this.safeAreaSetInitially)
{
this.SetSafeAreaOnContentContainer();
this.safeAreaSetInitially = true;
}
}
protected override void OnSizeAllocated(double width, double height)
{
base.OnSizeAllocated(width, height); //must be called
if (Math.Abs(this.width - width) > double.Epsilon || Math.Abs(this.height - height) > double.Epsilon)
{
this.width = width;
this.height = height;
if (this.width > this.height)
{
// reconfigure for landscape if needed
}
else
{
// reconfigure for portrait if needed
}
// reset safe area on rotation as the landscape/portrait safe areas are different
this.SetSafeAreaOnContentContainer();
}
}
private void SetSafeAreaOnContentContainer()
{
if (Device.RuntimePlatform == Device.iOS)
{
// set safe insets on content that you want to be within the safe area
var safeInsets = On<Xamarin.Forms.PlatformConfiguration.iOS>().SafeAreaInsets();
safeInsets.Top += 20; // add any other custom design margin specific to iOS (the extra 20 came from the original XAML)
this.scrollView.Margin = safeInsets;
}
}
结果
根据要求,另一种选择是只使用 BackgroundImage
Page
的属性(property)(它不受 On<Xamarin.Forms.PlatformConfiguration.iOS>().SetUseSafeArea(true)
方法的影响)。这种方法的一个问题是 BackgroundImage 在 iOS 中是“平铺的”。为了解决这个问题,创建一个自定义 Xamarin.Forms.ContentPage
不“平铺”BackgroundImage 的渲染器.这是一个 example .
关于ios - Xamarin.Forms 和 iOS : how to combine UseSafeArea and a background image?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51553694/
我是 os 2 的新手,所以真的不知道从哪里开始。是否可以编写一个 WatchOs 2 应用程序,它将在后台运行并每小时唤醒一次?网上没有那么多可用的信息,但到目前为止我所看到的表明不可能编写后台应用
如何将 url 背景图像添加到渐变中并具体定位?因为梯度本身被当作图像 CSS background: linear-gradient(to bottom, #98cb01 2%,#60a822 10
我是 android 开发的新手,正在开发我的第一个 android 应用程序。我在布局的 xml 中设置了 View 的背景颜色,如下所示。 android:background="@+color/
为了尽可能简洁地使用样式,如果使用双像素密度设备(例如 iPhone 4)查看我的页面,我宁愿不使用包含的媒体查询样式表。 话虽如此,如果我只是做这样的事情就可以了吗? .icon-1 { bac
我有一个由 62 张 91 * 91 像素的图像组成的 Sprite ,这使得整个图像为 91 * 5642 像素。它们以动态网格的形式显示,该网格会根据用户/指针的移动而增长和缩小。有时,一个元素(
我一直在尝试制作一款使用 Xbox One Kinect (V2) 的 Unity 游戏。 我遵循了本教程中的说明: http://www.imaginativeuniversal.com/blog/
看来firefox会自动组合一些东西,例如它需要单独的css值,例如“border-color”,“border-width”并将它们全部转储到“border”中..这使jquery变得很痛苦因为 .
我正在构建我的第一个 Chrome 扩展程序。我浏览了 Chrome 开发人员文档,但我无法理解几个主题。 我的理解: 有两个 Action : 浏览器操作(地址栏外的按钮) 页面操作(地址栏内的按钮
我的后台监听器是 chrome.runtime.onMessage.addListener(function (request, sender, sendResponse) 在chrome.conte
哪个更有效: 我正在尝试找出哪种提供半透明背景的方法更有效/更快: background-color: rgba(255, 255, 255, .12); 或者 background-image: u
我想要一个有 tr 作为黑色背景的表格,里面有一个白色背景的表格。
我在我的主页上放了一个背景。它可以在除 android chrome 之外的所有浏览器上正确显示。这是我的 CSS: body.path-frontpage { background-imag
我正在尝试对我的背景图像应用滤镜,但是我遇到了 CSS 属性 URL 和线性渐变的问题。我想要的背景图片 .bg-image-full { background: no-repeat center
在样式部分的 chrome 中使用谷歌开发者控制台时,它会立即为我提供“在我键入时”的背景颜色属性。几个月前,它一直在提供我更喜欢的一般属性(property)“背景”。 是否有机会自定义这些提示,或
我正在尝试实现 faux column网站上的布局。简而言之,它涉及在包含两个垂直列的 div 上平铺背景图像,使其看起来像两个列一直延伸到底部。 我的专栏如下所示: XXXX MMMM XXXX
这是一个 example .我想裁剪背景图像,然后将裁剪图像用作更大(尺寸)元素的背景。我的意思是 div 比它的背景大,我不需要重复。现在,当 background-repeat 取消注释时,元素消
CSS3 声明 background-clip 和 background-origin 似乎对背景有相同的效果。它们似乎都将背景限制在相对于 HTML 元素的某个区域,所以我想知道这两个声明在功能上是
我正在为图片库制作缩略图页面。缩略图预览作为 完成 float 具有固定的方形尺寸。 然而,缩略图本身不一定是正方形或相同大小,它们具有它们所代表的大图像的属性。 为了让它看起来不错,我想在正方形中
这个问题在这里已经有了答案: Get a CSS value with JavaScript (8 个答案) 关闭 6 年前。
你好, 就像我在标题中所说的 background-image:none; 不起作用,因为使用 css3 background-image:url('...'); 返回一个新层每次文件都是新的。我正在
我是一名优秀的程序员,十分优秀!