Share via


iOS での Picker の項目選択

この iOS プラットフォーム固有設定では、Picker で項目の選択が行われるタイミングが制御されます。これにより、ユーザーは、コントロール内の項目を参照するとき、または [完了] ボタンが押された後にのみ、項目を選択することを指定できます。 Picker.UpdateMode 添付プロパティを UpdateMode 列挙型の値に設定することで、XAML で使用されます。

<ContentPage ...
             xmlns:ios="clr-namespace:Xamarin.Forms.PlatformConfiguration.iOSSpecific;assembly=Xamarin.Forms.Core">
    <StackLayout Margin="20">
        <Picker ... Title="Select a monkey" ios:Picker.UpdateMode="WhenFinished">
          ...
        </Picker>
        ...
    </StackLayout>
</ContentPage>

あるいは、Fluent API を使用して C# から使用することもできます。

using Xamarin.Forms.PlatformConfiguration;
using Xamarin.Forms.PlatformConfiguration.iOSSpecific;
...

picker.On<iOS>().SetUpdateMode(UpdateMode.WhenFinished);

Picker.On<iOS> メソッドは、このプラットフォーム固有が iOS でのみ実行されるように指定します。 Xamarin.Forms.PlatformConfiguration.iOSSpecific 名前空間の Picker.SetUpdateMode メソッドは、項目の選択が行われるタイミングを制御するために使用され、UpdateMode 列挙は 2 つの可能な値を提供します。

  • Immediately: ユーザーが Picker で項目を参照すると、項目の選択が行われます。 これは、Xamarin.Forms の既定の動作です。
  • WhenFinished: 項目の選択は、ユーザーが Picker[完了] ボタンを押した後にのみ行われます。

さらに、SetUpdateMode メソッドを使用して、UpdateMode メソッドを呼び出して列挙値を切り替えることができます。このメソッドは現在の UpdateMode を返します。

switch (picker.On<iOS>().UpdateMode())
{
    case UpdateMode.Immediately:
        picker.On<iOS>().SetUpdateMode(UpdateMode.WhenFinished);
        break;
    case UpdateMode.WhenFinished:
        picker.On<iOS>().SetUpdateMode(UpdateMode.Immediately);
        break;
}

その結果、指定された UpdateModePicker に適用され、項目の選択がいつ行われるかを制御します。

Picker UpdateMode プラットフォーム固有