Xamarin Forms-图像元素在绝对布局中的按钮元素onclick下消失

问题描述

我有一个absolutelayout,其中的Button和Image放置在同一空间中,图像排在第二位。它只是将图像放置在按钮上我喜欢的位置,而不是使用ImageSource属性

当最初显示页面时,此方法工作正常,但是一旦按下这些按钮之一,上面的图像就会消失。它几乎像按Z顺序或其他方式落后-但是在我尝试做的OnClick方法

AbsoluteLayout.RaiseChild(image);

以及

AbsoluteLayout.Children.Remove(image);
AbsoluteLayout.Children.Insert(0,image);

但似乎都没有使它恢复可见性。

这仅仅是我的疏忽之处,还是有一种技巧可以将图像保持在顶部(或者,如果不是深度问题,则可以看到)

enter image description here

解决方法

此问题是由 Fast Renderers in Xamarin Forms 引起的。

您可以通过在调用MainActivity之前将以下代码行添加到Forms.Init类中来启用旧版渲染器:

Forms.SetFlags("UseLegacyRenderers");

这是我的Xaml代码:

<AbsoluteLayout x:Name="myAbsoluteLayout">
    <Button Text="Button"
            BackgroundColor="LightBlue"
            Clicked="Button_Clicked"
            x:Name="button"
            AbsoluteLayout.LayoutBounds="0.5,100,50"
            AbsoluteLayout.LayoutFlags="PositionProportional" />
    <Image x:Name="firstImage"
            Source="icon.png"
            InputTransparent="False"
            AbsoluteLayout.LayoutBounds="0.5,25,25"
            AbsoluteLayout.LayoutFlags="PositionProportional" />
</AbsoluteLayout>

效果:

enter image description here