質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
UWP

UWPは、Universal Windows Platformの略。様々なデバイス向けに提供されているアプリケーションを共通のフレームワーク上で動作可能にする仕組みで、Windows10で導入されました。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

UI

UIはUser Interfaceの略であり、人間がコンピュータとやりとりをするためのシステムです。

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

Xamarin

Xamarin(ザマリン)は、iPhoneなどのiOSやAndroidで動作し、C# 言語を用いてアプリを開発できるクロスプラットフォーム開発環境です。Xamarin Studioと C# 言語を用いて、 iOS と Android の両方の開発を行うことができます。

Q&A

解決済

1回答

2252閲覧

Buttonを押下したときPickerのドロップダウンを開くようにしたい

hige5656

総合スコア2

UWP

UWPは、Universal Windows Platformの略。様々なデバイス向けに提供されているアプリケーションを共通のフレームワーク上で動作可能にする仕組みで、Windows10で導入されました。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

UI

UIはUser Interfaceの略であり、人間がコンピュータとやりとりをするためのシステムです。

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

Xamarin

Xamarin(ザマリン)は、iPhoneなどのiOSやAndroidで動作し、C# 言語を用いてアプリを開発できるクロスプラットフォーム開発環境です。Xamarin Studioと C# 言語を用いて、 iOS と Android の両方の開発を行うことができます。

0グッド

0クリップ

投稿2021/09/07 01:55

前提・実現したいこと

Xamarin FormsにてButtonを押下したときPickerのドロップダウンを開くようにしたい

発生している問題・エラーメッセージ

標準のPickerではなく、こちらで用意したButtonの画像を使用した独自のComboBoxを作ろうとしています。

UWPアプリのため、UWPのCustomPickerを作ってみましたが、
IsDropDownOpen=trueでPickerのドロップダウンを開こうとしただけではWindows.UI.Xaml.UnhandleExceptionEventArfsが発生してしまいます。
CustomPickerに限らず、ボタンを押下することによりPickerドロップダウンを開く方法がありますでしょうか。

該当のソースコード

カスタムピッカー

C#

1namespace a 2{ 3 public class CustomPicker : picker 4 { 5 public CustomPicker() : base() 6 { 7 8 } 9 } 10} 11

UWPのネイティブコントロール

C#

1[assembly: ExportRenderer(typeof(CustomPicker), typeof(CustomPickerRenderer))] 2namespace a.UWP 3{ 4 class CustomPickerRenderer : PickerRenderer 5 { 6 protected override void OnElementChanged(ElementChangedEventArgs<Picker> e) 7 { 8 base.OnElementChanged(e); 9 10 if (Control != null) 11 { 12 Control.IsDropDownOpen = true; 13 } 14 } 15 } 16}

Pickerのドロップダウンを開く方法が中々見つからず(おそらくできないのでは)、
UWPのCustomPickerで対応する場合も情報が見つからないため、どなたかお教えいただけますでしょうか。

補足情報(FW/ツールのバージョンなど)

VisualStudio2017

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

カスタムレンダラーで作ってみました。ボタン押下時にIsOpentrueにすればドロップダウンが開きます。

C#

1namespace a 2{ 3 public class CustomPicker: Picker 4 { 5 public static readonly BindableProperty IsOpenProperty = 6 BindableProperty.Create(nameof(IsOpen), typeof(bool), typeof(CustomPicker), false, BindingMode.TwoWay); 7 8 public bool IsOpen 9 { 10 get { return (bool)GetValue(IsOpenProperty); } 11 set { SetValue(IsOpenProperty, value); } 12 } 13 14 } 15}

C#

1[assembly: ExportRenderer(typeof(CustomPicker), typeof(CustomPickerRenderer))] 2namespace a.UWP 3{ 4 public class CustomPickerRenderer : PickerRenderer 5 { 6 protected override void OnElementChanged(ElementChangedEventArgs<Picker> e) 7 { 8 base.OnElementChanged(e); 9 10 if(e.OldElement != null) 11 { 12 if(Control != null) 13 { 14 Control.DropDownOpened -= OnDropDownOpened; 15 Control.DropDownClosed -= OnDropDownClosed; 16 } 17 } 18 if(e.NewElement != null) 19 { 20 Control.DropDownOpened += OnDropDownOpened; 21 Control.DropDownClosed += OnDropDownClosed; 22 } 23 } 24 25 protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e) 26 { 27 base.OnElementPropertyChanged(sender, e); 28 29 if(e.PropertyName == CustomPicker.IsOpenProperty.PropertyName) 30 { 31 Control.IsDropDownOpen = ((CustomPicker)Element).IsOpen; 32 } 33 } 34 35 private void OnDropDownOpened(object sender, object o) 36 { 37 ((CustomPicker)Element).IsOpen = true; 38 } 39 40 private void OnDropDownClosed(object sender, object o) 41 { 42 ((CustomPicker)Element).IsOpen = false; 43 } 44 } 45}

投稿2021/09/12 18:38

f-miyu

総合スコア1625

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hige5656

2021/09/13 23:59

ご回答ありがとうございます! 無事、開けるようになりました。 半分諦めていましたが、カスタムレンダラーの知識が足りていないようなので、もっと調べてみることにします。 本当にありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問