如何在 Xamarin Picker 中设置项目列表的样式(在 Android 中)

Ori*_*Bri 4 android themes picker xamarin.android xamarin

我有一个 Xamarin Android 应用程序,它使用 Picker 从值列表中进行选择。我一直在更改应用程序的样式,但在使用 Picker 时遇到了问题。虽然我可以设置 TextColor,但我无法设置占位符文本的颜色。

在搜索 SO 寻求帮助后,我实现了一个自定义渲染器,现在我的文本和占位符显示在正确的文本中。然而,以前当我触摸占位符文本时,子对话框出现并显示所有项目,允许用户选择一个。现在我实现了自定义渲染器,子对话框只显示前两个项目,用户必须在点击确定之前滚动它们。

我有两个问题:

  1. 至少,如何让子对话框再次显示完整列表?
  2. 是否可以为项目列表对话框设置背景和文本颜色?

XAML 看起来像这样:

<c:CustomPicker x:Name="DivisionList" Title="{x:Static prop:Resources.PickerDivision}" 
                        SelectedIndexChanged="DivisionList_SelectedIndexChanged">
    <Picker.Behaviors>
        <b:RequiredPickerValidator x:Name="DivValidator" IsValid="{Binding Path=BindingContext.IsDivisionValid, Mode=OneWayToSource, Source={x:Reference contentPage}}" />
    </Picker.Behaviors>
</c:CustomPicker>
Run Code Online (Sandbox Code Playgroud)

CustomPicker 类如下:

namespace <myapp>.Portable.Controls
{
    public class CustomPicker : Picker
    {
        public Color PlaceholderColour
        {
            get { return (Color)App.Current.Resources["PlaceholderTextColour"]; }
        }

        public Color TextColour
        {
            get { return (Color)App.Current.Resources["LabelTextColour"]; }
        }

        public Color BackgroundColour
        {
            get { return (Color)App.Current.Resources["PaneBackgroundColour"]; }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

客户渲染器是这样的:

[assembly: ExportRendererAttribute(typeof(CustomPicker), typeof(CustomPickerRenderer))]
namespace <myapp>.Droid.Controls.Renderers
{
    public class CustomPickerRenderer : PickerRenderer
    {
        protected override void OnElementChanged(ElementChangedEventArgs<Picker> e)
        {
            base.OnElementChanged(e);

            Control?.SetPadding(20, 20, 20, 20);
            if (e.OldElement != null || e.NewElement != null)
            {
                var customPicker = e.NewElement as CustomPicker;

                Android.Graphics.Color phCol = customPicker.PlaceholderColour.ToAndroid();
                Android.Graphics.Color textCol = customPicker.TextColour.ToAndroid();
                Android.Graphics.Color bgCol = customPicker.BackgroundColour.ToAndroid();

                Control.SetBackgroundColor(bgCol);
                Control.SetHintTextColor(phCol);
                Control.SetTextColor(textCol);
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

提前谢谢了!

自定义渲染器之前的选择器弹出窗口: 自定义渲染器之前的选择器弹出窗口

自定义渲染器后的选择器弹出窗口: 自定义渲染器后弹出选择器

小智 7

似乎有 2 个选择器渲染器。

Xamarin.Forms.Platform.Android.PickerRendererXamarin.Forms.Platform.Android.AppCompat.PickerRenderer

确保您使用最后一个,您的布局将与以前相同!!!

我得到答案的来源:https : //forums.xamarin.com/discussion/97150/how-to-write-a-custom-renderer-for-bindable-picker-to-change-its-font-attributes-家庭规模

渲染器(没有真正的迹象有 2 个):https : //docs.microsoft.com/en-us/xamarin/xamarin-forms/app-fundamentals/custom-renderer/renderers