【问题标题】:Xamarin.Forms Spinner TimePickerXamarin.Forms 微调器 TimePicker
【发布时间】:2020-07-10 12:40:50
【问题描述】:

在 xamarin.forms 中,timepicker 默认为时钟视图。我想使用微调器版本,因为这更适合最终用户。

我在我的 .xaml 文件中尝试过这个

<?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:d="http://xamarin.com/schemas/2014/forms/design"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
             xmlns:system="clr-namespace:System;assembly=netstandard"
             mc:Ignorable="d"
             x:Class="namespace.Pages.HoursWorkedPage">
    <ContentPage.Content>
        <StackLayout>
            <DatePicker
                MinimumDate="{Binding Source=(system:DateTime.Now())}" 
                DateSelected="DatePick  er_DateSelected"/>
            <TimePicker
                Format="T"
                android:timePickerMode="spinner"/>
                Time="{Binding Source=(system:DateTime.Now.TimeOfDay())}"
                PropertyChanging="OnTimeChanged"
                SpinnerFormatString="t"
        </StackLayout>
    </ContentPage.Content>
</ContentPage>

但它给了我一个错误,即 android 不是 contentpage 的一部分。

我一直在寻找整个互联网,但我似乎无法修复它。

【问题讨论】:

    标签: c# android ios xamarin xamarin.forms


    【解决方案1】:

    你想达到如下gif的效果吗?

    如果是这样,您应该为您的 timePicker 创建一个自定义渲染器。

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    
    using Android.App;
    using Android.Content;
    using Android.OS;
    using Android.Runtime;
    using Android.Views;
    using Android.Widget;
    using App3.Droid;
    using Xamarin.Forms;
    using Xamarin.Forms.Platform.Android;
    
    [assembly: ExportRenderer(typeof(Xamarin.Forms.TimePicker), typeof(MyTimePicker))]
    namespace App3.Droid
    {
        public class MyTimePicker : TimePickerRenderer
        {
            public MyTimePicker(Context context) : base(context)
            {
    
            }
    
            protected override void OnElementChanged(ElementChangedEventArgs<Xamarin.Forms.TimePicker> e)
            {
                base.OnElementChanged(e);
    
                TimePickerDialogIntervals timePickerDlg = new TimePickerDialogIntervals(this.Context, new EventHandler<TimePickerDialogIntervals.TimeSetEventArgs>(UpdateDuration),
                    Element.Time.Hours, Element.Time.Minutes, true);
    
    
                var control = new EditText(this.Context);
    
                control.Focusable = false;
                control.FocusableInTouchMode = false;
                control.Clickable = false;
                control.Click += (sender, ea) => timePickerDlg.Show();
                control.Text = Element.Time.Hours.ToString("00") + ":" + Element.Time.Minutes.ToString("00");
    
               
    
                SetNativeControl(control);
            }
    
            void UpdateDuration(object sender, Android.App.TimePickerDialog.TimeSetEventArgs e)
            {
                Element.Time = new TimeSpan(e.HourOfDay, e.Minute, 0);
                Control.Text = Element.Time.Hours.ToString("00") + ":" + Element.Time.Minutes.ToString("00");
            }
        }
    
        public class TimePickerDialogIntervals : TimePickerDialog
        {
            public const int TimePickerInterval = 15;
            private bool _ignoreEvent = false;
    
            public TimePickerDialogIntervals(Context context, EventHandler<TimePickerDialog.TimeSetEventArgs> callBack, int hourOfDay, int minute, bool is24HourView)
                : base(context, TimePickerDialog.ThemeHoloLight, (sender, e) =>
                {
                    callBack(sender, new TimePickerDialog.TimeSetEventArgs(e.HourOfDay, e.Minute * 5));
                }, hourOfDay, minute / TimePickerInterval, is24HourView)
            {
              
            }
    
            protected TimePickerDialogIntervals(IntPtr javaReference, JniHandleOwnership transfer) : base(javaReference, transfer)
            {
            }
    
            public override void SetView(Android.Views.View view)
            {
                SetupMinutePicker(view);
                base.SetView(view);
            }
    
            void SetupMinutePicker(Android.Views.View view)
            {
                var numberPicker = FindMinuteNumberPicker(view as ViewGroup);
                if (numberPicker != null)
                {
                    numberPicker.MinValue = 0;
                    numberPicker.MaxValue = 11;
                    numberPicker.SetDisplayedValues(new String[] { "00", "05", "10", "15", "20", "25", "30", "35", "40", "45", "50", "55" });
                }
            }
    
            protected override void OnCreate(Android.OS.Bundle savedInstanceState)
            {
                base.OnCreate(savedInstanceState);
                GetButton((int)DialogButtonType.Negative).Visibility = Android.Views.ViewStates.Gone;
                this.SetCanceledOnTouchOutside(false);
    
            }
    
            private NumberPicker FindMinuteNumberPicker(ViewGroup viewGroup)
            {
                for (var i = 0; i < viewGroup.ChildCount; i++)
                {
                    var child = viewGroup.GetChildAt(i);
                    var numberPicker = child as NumberPicker;
                    if (numberPicker != null)
                    {
                        if (numberPicker.MaxValue == 59)
                        {
                            return numberPicker;
                        }
                    }
    
                    var childViewGroup = child as ViewGroup;
                    if (childViewGroup != null)
                    {
                        var childResult = FindMinuteNumberPicker(childViewGroup);
                        if (childResult != null)
                            return childResult;
                    }
                }
    
                return null;
            }
    
          
        }
    }
    
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2018-08-07
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-04-08
      相关资源
      最近更新 更多