Frame OutlineColor不仅适用于Android,Xamarin Forms

时间:2017-11-25 10:08:45

标签: android xamarin.forms frame

我正在开发Xamarin Forms中的应用程序,我遇到了一个应该在很久以前修复的错误。 我试图设置框架的轮廓,它在ios上运行良好,但在android上不起作用。

这是我的框架的xaml。

<Frame
    HasShadow="true"
    CornerRadius="10"
    OutlineColor="Red"
    BackgroundColor="White">
    <StackLayout 
        Orientation="Horizontal">
        <Label
        Text="TEST"
        VerticalOptions="Center"/>
        <Label
        Text="For OUTLINE"
        VerticalOptions="Center"/>
    </StackLayout>
</Frame>

感谢您的帮助!

2 个答案:

答案 0 :(得分:4)

这对Android没有用。报告错误here

解决方案1:

您应该为Android平台Renderer制作Frame,如下所示:

using System;
using Android.Graphics.Drawables;
using Xamarin.Forms;
using Xamarin.Forms.Platform.Android;
using XFormsUI.Droid;

[assembly: ExportRenderer(typeof(Frame), typeof(RoundBorderFrameRenderer))]
namespace XFormsUI.Droid
{
    public class RoundBorderFrameRenderer : FrameRenderer
    {
        protected override void OnElementChanged(ElementChangedEventArgs<Frame> e)
        {
            base.OnElementChanged(e);

            if (e.NewElement != null && e.OldElement == null)
            {
                SetBackgroundResource(Resource.Drawable.round_border_frame);

                //Write following lines if you want to bring the XAML Frame Elements's background Color into Native. Otherwise, Frame's BackgroundColor will not be effective.
                GradientDrawable drawable = (GradientDrawable)Background;
                string FrameBackgroundColorHex = String.Format("#{0:X2}{1:X2}{2:X2}", (int)(e.NewElement.BackgroundColor.R * 255), (int)(e.NewElement.BackgroundColor.G * 255), (int)(e.NewElement.BackgroundColor.B * 255));
                drawable.SetColor(Android.Graphics.Color.ParseColor(FrameBackgroundColorHex));
            }
        }
    }
}

这还需要xml (round_border_frame.xml)个选择器文件。将此文件放在Drawable文件夹中。

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
    <!--We need to give Frame's 'BorderColor Here-->
    <stroke android:width="1dp" android:color="#FF0000" />
    <corners android:radius="10dp" />
</shape>

解决方案2:

使用不带选择器xml文件的RendererSource

using System;
using Android.Graphics;
using Xamarin.Forms;
using Xamarin.Forms.Platform.Android;
using XFormsUI.Droid;

[assembly: ExportRenderer(typeof(Frame), typeof(RoundBorderFrameRenderer))]
namespace XFormsUI.Droid
{
    public class RoundBorderFrameRenderer : FrameRenderer
    {
        public override void Draw(Canvas canvas)
        {
            base.Draw(canvas);

            using (var paint = new Paint { AntiAlias = true })
            using (var path = new Path())
            using (Path.Direction direction = Path.Direction.Cw)
            using (Paint.Style style = Paint.Style.Stroke)
            using (var rect = new RectF(0, 0, canvas.Width, canvas.Height))
            {
                float px = Forms.Context.ToPixels(Element != null ? Element.CornerRadius : 10); //Default Corner Radius = 10
                float py = Forms.Context.ToPixels(Element != null ? Element.CornerRadius : 10); //Default Corner Radius = 10
                path.AddRoundRect(rect, px, py, direction);

                //Set the Width of the Border here
                paint.StrokeWidth = 1f;
                paint.SetStyle(style);

                //Take OutLineColor from XAML Frame element and set it natively here.
                string FrameBorderColorHex = String.Format("#{0:X2}{1:X2}{2:X2}", (int)(Element.OutlineColor.R * 255), (int)(Element.OutlineColor.G * 255), (int)(Element.OutlineColor.B * 255));
                paint.Color = Android.Graphics.Color.ParseColor(FrameBorderColorHex);
                canvas.DrawPath(path, paint);
            }
        }
    }
}

解决方案3:

然而,这不是最佳解决方案,但它是一种解决方法: 将您的Frame外部Frame包含在Padding的另一个BackgroundColor内,并将其<Frame BackgroundColor="Red" CornerRadius="10" Padding="1,1,1,1"> <Frame CornerRadius="10" BackgroundColor="White"> <StackLayout Orientation="Horizontal"> <Label Text="TEST" VerticalOptions="Center" /> <Label Text="For OUTLINE" VerticalOptions="Center" /> </StackLayout> </Frame> </Frame> 设置为您的边框颜色应该是什么。

注意:我还没有在iOS上检查过这个问题。

var=0

人们正在讨论thread

希望这会有所帮助!!

答案 1 :(得分:0)

这个问题我被困了半天......

我的解决方案:

{{1}}