[iOS] Fix NavBar issues on iOS 13 (#10493)

* Created repro sample

* Fixed #10337 and #10338

* Update Xamarin.Forms.Platform.iOS/Renderers/NavigationRenderer.cs

Co-Authored-By: Samantha Houts <samhouts@users.noreply.github.com>

* Update NavigationRenderer.cs

Co-authored-by: Rui Marinho <me@ruimarinho.net>
Co-authored-by: Samantha Houts <samhouts@users.noreply.github.com>

fixes #10337
fixes #10338
This commit is contained in:
Javier Suárez 2020-05-07 02:38:31 +02:00 коммит произвёл GitHub
Родитель 7938a26460
Коммит 5276134af5
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: 4AEE18F83AFDEB23
5 изменённых файлов: 148 добавлений и 10 удалений

Просмотреть файл

@ -138,6 +138,7 @@
<Compile Include="ApiLabelRenderer.cs" /> <Compile Include="ApiLabelRenderer.cs" />
<Compile Include="CustomRenderers\CustomSearchBarRenderer.cs" /> <Compile Include="CustomRenderers\CustomSearchBarRenderer.cs" />
<Compile Include="_9767CustomRenderer.cs" /> <Compile Include="_9767CustomRenderer.cs" />
<Compile Include="_10337CustomRenderer.cs" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\Xamarin.Forms.Controls\Xamarin.Forms.Controls.csproj"> <ProjectReference Include="..\Xamarin.Forms.Controls\Xamarin.Forms.Controls.csproj">

Просмотреть файл

@ -0,0 +1,21 @@
using UIKit;
using Xamarin.Forms;
using Xamarin.Forms.ControlGallery.iOS;
using Xamarin.Forms.Controls.Issues;
using Xamarin.Forms.Platform.iOS;
[assembly: ExportRenderer(typeof(Issue10337NavigationPage), typeof(_10337CustomRenderer))]
namespace Xamarin.Forms.ControlGallery.iOS
{
public class _10337CustomRenderer : NavigationRenderer
{
public override void ViewDidLoad()
{
base.ViewDidLoad();
NavigationBar.ShadowImage = new UIImage();
UINavigationBar.Appearance.BackIndicatorImage = new UIImage();
UINavigationBar.Appearance.BackIndicatorTransitionMaskImage = new UIImage();
}
}
}

Просмотреть файл

@ -0,0 +1,64 @@
using Xamarin.Forms.CustomAttributes;
using Xamarin.Forms.Internals;
#if UITEST
using Xamarin.Forms.Core.UITests;
using Xamarin.UITest;
using NUnit.Framework;
#endif
namespace Xamarin.Forms.Controls.Issues
{
#if UITEST
[Category(UITestCategories.Navigation)]
#endif
[Preserve(AllMembers = true)]
[Issue(IssueTracker.Github, 10337, "[Bug]iOS Renderer NavigationBar.ShadowImage = new UIImage() not remove shadow line after xamarin.forms 4.5", PlatformAffected.iOS)]
public class Issue10337 : TestNavigationPage
{
public Issue10337()
{
var page = new ContentPage
{
Title = "Issue 10337"
};
var layout = new StackLayout();
var navigateButton = new Button
{
Text = "Navigate using Custom NavigationPage"
};
navigateButton.Clicked += (sender, args) =>
{
Navigation.PushAsync(new Issue10337NavigationPage(new Issue10337()));
};
layout.Children.Add(navigateButton);
page.Content = layout;
PushAsync(page);
}
protected override void Init()
{
}
}
[Preserve(AllMembers = true)]
public class Issue10337NavigationPage : NavigationPage
{
public Issue10337NavigationPage()
{
}
public Issue10337NavigationPage(Page root) : base(root)
{
}
}
}

Просмотреть файл

@ -1297,6 +1297,7 @@
<Compile Include="$(MSBuildThisFileDirectory)Issue9417.xaml.cs" /> <Compile Include="$(MSBuildThisFileDirectory)Issue9417.xaml.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Issue8272.cs" /> <Compile Include="$(MSBuildThisFileDirectory)Issue8272.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Issue8964.cs" /> <Compile Include="$(MSBuildThisFileDirectory)Issue8964.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Issue10337.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Issue9794.cs" /> <Compile Include="$(MSBuildThisFileDirectory)Issue9794.cs" />
<Compile Include="$(MSBuildThisFileDirectory)Issue10438.cs" /> <Compile Include="$(MSBuildThisFileDirectory)Issue10438.cs" />
</ItemGroup> </ItemGroup>

Просмотреть файл

@ -659,7 +659,10 @@ namespace Xamarin.Forms.Platform.iOS
if (barBackgroundColor == Color.Default) if (barBackgroundColor == Color.Default)
{ {
navigationBarAppearance.ConfigureWithDefaultBackground(); navigationBarAppearance.ConfigureWithDefaultBackground();
navigationBarAppearance.BackgroundColor = UINavigationBar.Appearance.BarTintColor; navigationBarAppearance.BackgroundColor = null;
var parentingViewController = GetParentingViewController();
parentingViewController?.SetupDefaultNavigationBarAppearance();
} }
else else
{ {
@ -670,9 +673,6 @@ namespace Xamarin.Forms.Platform.iOS
NavigationBar.CompactAppearance = navigationBarAppearance; NavigationBar.CompactAppearance = navigationBarAppearance;
NavigationBar.StandardAppearance = navigationBarAppearance; NavigationBar.StandardAppearance = navigationBarAppearance;
NavigationBar.ScrollEdgeAppearance = navigationBarAppearance; NavigationBar.ScrollEdgeAppearance = navigationBarAppearance;
var parentingViewController = GetParentingViewController();
parentingViewController?.UpdateNavigationBarBackgroundImage();
} }
else else
#endif #endif
@ -1070,7 +1070,7 @@ namespace Xamarin.Forms.Platform.iOS
public override void ViewWillAppear(bool animated) public override void ViewWillAppear(bool animated)
{ {
UpdateNavigationBarBackgroundImage(); SetupDefaultNavigationBarAppearance();
UpdateNavigationBarVisibility(animated); UpdateNavigationBarVisibility(animated);
NavigationRenderer n; NavigationRenderer n;
@ -1136,7 +1136,7 @@ namespace Xamarin.Forms.Platform.iOS
UpdateTitleArea(Child); UpdateTitleArea(Child);
} }
internal void UpdateNavigationBarBackgroundImage() internal void SetupDefaultNavigationBarAppearance()
{ {
if (!Forms.IsiOS13OrNewer) if (!Forms.IsiOS13OrNewer)
return; return;
@ -1145,14 +1145,65 @@ namespace Xamarin.Forms.Platform.iOS
return; return;
#if __XCODE11__ #if __XCODE11__
var backgroundImage = navigationRenderer.NavigationBar.GetBackgroundImage(UIBarMetrics.Default);
navigationRenderer.NavigationBar.CompactAppearance.BackgroundImage = backgroundImage; // We will use UINavigationBar.Appareance to infer settings that
navigationRenderer.NavigationBar.StandardAppearance.BackgroundImage = backgroundImage; // were already set to navigation bar in older versions of
navigationRenderer.NavigationBar.ScrollEdgeAppearance.BackgroundImage = backgroundImage; // iOS.
var navBar = navigationRenderer.NavigationBar;
var navAppearance = navBar.StandardAppearance;
if (navAppearance.BackgroundColor == null)
{
var backgroundColor = navBar.BarTintColor;
navBar.CompactAppearance.BackgroundColor = navBar.StandardAppearance.BackgroundColor = navBar.ScrollEdgeAppearance.BackgroundColor = backgroundColor;
}
if (navAppearance.BackgroundImage == null)
{
var backgroundImage = navBar.GetBackgroundImage(UIBarMetrics.Default);
navBar.CompactAppearance.BackgroundImage = navBar.StandardAppearance.BackgroundImage = navBar.ScrollEdgeAppearance.BackgroundImage = backgroundImage;
}
if (navAppearance.ShadowImage == null)
{
var shadowImage = navBar.ShadowImage;
navBar.CompactAppearance.ShadowImage = navBar.StandardAppearance.ShadowImage = navBar.ScrollEdgeAppearance.ShadowImage = shadowImage;
if (shadowImage != null && shadowImage.Size == SizeF.Empty)
navBar.CompactAppearance.ShadowColor = navBar.StandardAppearance.ShadowColor = navBar.ScrollEdgeAppearance.ShadowColor = UIColor.Clear;
}
UIImage backIndicatorImage = navBar.BackIndicatorImage;
UIImage backIndicatorTransitionMaskImage = navBar.BackIndicatorTransitionMaskImage;
if (backIndicatorImage != null && backIndicatorImage.Size == SizeF.Empty)
backIndicatorImage = GetEmptyBackIndicatorImage();
if (backIndicatorTransitionMaskImage != null && backIndicatorTransitionMaskImage.Size == SizeF.Empty)
backIndicatorTransitionMaskImage = GetEmptyBackIndicatorImage();
navBar.CompactAppearance.SetBackIndicatorImage(backIndicatorImage, backIndicatorTransitionMaskImage);
navBar.StandardAppearance.SetBackIndicatorImage(backIndicatorImage, backIndicatorTransitionMaskImage);
navBar.ScrollEdgeAppearance.SetBackIndicatorImage(backIndicatorImage, backIndicatorTransitionMaskImage);
#endif #endif
} }
UIImage GetEmptyBackIndicatorImage()
{
var rect = RectangleF.Empty;
var size = rect.Size;
UIGraphics.BeginImageContext(size);
var context = UIGraphics.GetCurrentContext();
context.SetFillColor(1, 1, 1, 0);
context.FillRect(rect);
var empty = UIGraphics.GetImageFromCurrentImageContext();
context.Dispose();
return empty;
}
internal void UpdateLeftBarButtonItem(Page pageBeingRemoved = null) internal void UpdateLeftBarButtonItem(Page pageBeingRemoved = null)
{ {
NavigationRenderer n; NavigationRenderer n;