создание пользовательского рендеринга в формах xamarin вылетает, когда приложение находится в режиме прерывания - PullRequest
0 голосов
/ 14 июля 2020

Я следил за видео о создании пользовательского рендеринга для форм xamarin на: https://www.youtube.com/watch?v=ux09gAB13kQ (спасибо Houssem Dellai) .... код выглядит следующим образом:

In В основном решении проекта добавьте класс

public class RoundedEntry : Entry
{
}

в решение android добавьте:

 [assembly: ExportRenderer(typeof(RoundedEntry), typeof(RoundedEntryRendererAndroid))]
namespace Project.Droid
{
    public class RoundedEntryRendererAndroid : EntryRenderer
    {
        protected override void OnElementChanged(ElementChangedEventArgs<Entry> e)
        {
            base.OnElementChanged(e);

            if(e.OldElement == null)
            {
                //Use this code if want to use button from XAML page
               // Control.SetBackgroundResource(Resource.Layout.RoundedShape);

                
                //Use this button if you want to create button from c#
            var gradientDrawable = new GradientDrawable();
            gradientDrawable.SetCornerRadius(60f);
            gradientDrawable.SetStroke(5, Android.Graphics.Color.DeepPink);
            gradientDrawable.SetColor(Android.Graphics.Color.LightGray);
            Control.SetBackground(gradientDrawable);

            Control.SetPadding(50, Control.PaddingTop, Control.PaddingRight,
               Control.PaddingBottom);

            }
        }

        public RoundedEntryRendererAndroid()
           : base(null)
        {
            // Default constructor needed for Xamarin Forms bug?
            throw new Exception("This constructor should not actually ever be used");
        }
    }
}

и в IOS добавьте:

  [assembly: ExportRenderer(typeof(RoundedEntry), typeof(RoundedEntryRendererIos))]
namespace Project.iOS
{
    public class RoundedEntryRendererIos : EntryRenderer
    {
        protected override void OnElementChanged(ElementChangedEventArgs<Entry> e)
        {
            base.OnElementChanged(e);

            if(e.OldElement == null)
            {
                Control.Layer.CornerRadius = 20;
                Control.Layer.BorderWidth = 3f;
                Control.Layer.BorderColor = Color.DeepPink.ToCGColor();
                Control.Layer.BackgroundColor = Color.LightGray.ToCGColor();

                Control.LeftView = new UIKit.UIView(new CGRect(0, 0, 10, 0));
                Control.LeftViewMode = UIKit.UITextFieldViewMode.Always;
            }
        }
    }
}

Затем, когда кнопка нажата, загрузите testPage с пользовательским рендерингом:

 <Button Text="Order" Clicked="ProceedToCheckout" HorizontalOptions="End"></Button>

void ProceedToCheckout(object sender, EventArgs e)
        {
              Application.Current.MainPage = new NavigationPage(new TestPage());
        }


<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             xmlns:local="clr-namespace:Lagans"
             x:Class="Lagans.Views.TestPage">
    
        <local:RoundedEntry></local:RoundedEntry>


</ContentPage>

namespace Projects.Views
{
    [XamlCompilation(XamlCompilationOptions.Compile)]
    public partial class TestPage : ContentPage
    {
        public TestPage ()
        {
            InitializeComponent ();
        }
    }
}

Однако при загрузке testpage проект вылетает с ошибкой: приложение находится в режиме прерывания.

public TestPage ()
        {
            InitializeComponent ();
        }

с точкой останова. но затем происходит сбой

Я запускаю проект в проекте android.

Кто-нибудь знает, что я делаю неправильно? спасибо

Ответы [ 2 ]

0 голосов
/ 15 июля 2020

Я думаю, вам нужно определить родительский макет на странице содержимого. Может быть, <Stacklayout> подойдет.

<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             xmlns:local="clr-namespace:Lagans"
             x:Class="Lagans.Views.TestPage">
    <Stacklayout>
        <local:RoundedEntry></local:RoundedEntry>
    </Stacklayout>

</ContentPage>
0 голосов
/ 15 июля 2020

Я просто использую ваш код, и у меня все работает хорошо. Я тестирую его на стороне Android и iOS.

Я загрузил свой образец проекта сюда , и вы можете его проверить.

Пожалуйста, не стесняйтесь спрашивать меня любой вопрос, если у вас есть.

Вот результат:

введите описание изображения здесь

...