0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Android の Spinner を簡単に使う

Last updated at Posted at 2021-06-03

#はじめに
数年ぶりに Android のアプリを書こうとしたら、Android Studio は(以前は Eclipse でしたが)随分高機能化したようでしたが、UI 開発周りの IDE での補助が 25 年以上前の MFC にも劣るように感じられました(個人の感想です)。
Android2.x 時代から私が(作って)使っているユーティリティクラスのようなコードのデザインパターンを検索しても見かけなかったので(よく探せばあるかもしれませんが)、ここでは Spinner のユーティリティクラスを紹介します。

#Spinnerとは?
Win32 のコンボボックス(ドロップダウンリスト)に相当するUIです。
https://developer.android.com/guide/topics/ui/controls/spinner?hl=ja
spinner.png

#使い方
クラスのソースコードは最後に付加しておきますので、まずは使い方を説明します。
まずは以下のような準備をします。

private UIDialog.SimpleSpinner  m_smplSpin ;

// 表示項目
String[] spinNameArray = { "リスト1", "リスト2", "リスト3", ... } ;

// 対象のスピナー
Spinner spinner = view.findViewById( R.id.対象のスピナー) ;

// 準備
int numSpinner = 1 ;  // ← "リスト2" を初めに選択する
m_smplSpin = new UIDialog.SimpleSpinner
	( spinner, numSpinner, spinNameArray , null) ;

spinner は findViewById でも、binding でも、何か好きな方法で取得してください。
そして、値を取得したいタイミングで

int indexSelected = m_smplSpin.getSelectionIndex() ;

を呼び出すと indexSelected に選択された番号(0~)が取得できます。
選択されていないときは -1 になります。

もし、番号が 0 からの連番でない場合には

int[] spinNumArray = { 0, -1, 1, ... } ;
int numSpinner = 1 ;  // ← "リスト3" を初めに選択する
m_smplSpin = new UIDialog.SimpleSpinner
	( spinner, numSpinner, spinNameArray, spinNumArray ) ;

のように、int[] を渡しておくといい感じにやってくれて、結果は同様に getSelectionIndex 又は、

int numSelected = m_smplSpin.getSelectionNum( -2 ) ;

で取得します。引数は選択されていないときに返却する値を指定します。
getSelectionIndex は 0~ の連番、getSelectionNum は対応する任意の値を返します。

選択が変更されたときに処理をしたい場合には結局リスナを派生することになりますが、以下のようにします。

m_smplSpin = new UIDialog.SimpleSpinner
	( spinner, numSpinner, spinNameArray, spinNumArray
		new UIDialog.SimpleSpinnerListener()
		{
			@Override
			public void onSelected( SimpleSpinner spinner, int index )
			{
				// 何かの処理...
			}
		}
} ;

これでも一応、値が連番でないときや、選択されていない状態を index に -1 で受け取れるなど、コードの簡略化が出来るなどの利点は一応あります。

大抵の UI 要素はシンプルなデフォルトの挙動で十分なことが多いと思いますのでコードを簡略化できます。

#ソース

以下がソースです。
UIDialog と言うクラスの中に入っていますが外に出しても問題無いと思います。
(実際には他にもいろいろ入っていますが、ここでは省略して Spinner 部分だけ記載します)

public class	UIDialog
{
	// スピナー通知
	public interface SimpleSpinnerListener
	{
		public abstract void onSelected( SimpleSpinner spinner, int index ) ;
	}

	// スピナーアイテム・ユーティリティ
	public static class SimpleSpinner   implements AdapterView.OnItemSelectedListener
	{
		private Spinner                 m_spinner = null ;
		private int                     m_selection = 0 ;
		private String[]                m_aTextArray = null ;
		private int[]                   m_aNumArray = null ;
		private SimpleSpinnerListener   m_listener = null ;

		public SimpleSpinner
			( Spinner spinner, int iFirstNum, String[] aTextArray, int[] aNumArray )
		{
			m_aTextArray = aTextArray ;
			m_aNumArray = aNumArray ;
			setupSpinner
				( spinner, iFirstNum,
					android.R.layout.simple_spinner_item,
					android.R.layout.simple_spinner_dropdown_item ) ;
		}
		public SimpleSpinner
			( Spinner spinner, int iFirstNum,
				String[] aTextArray, int[] aNumArray, SimpleSpinnerListener listener )
		{
			m_aTextArray = aTextArray ;
			m_aNumArray = aNumArray ;
			m_listener = listener ;
			setupSpinner
				( spinner, iFirstNum,
					android.R.layout.simple_spinner_item,
					android.R.layout.simple_spinner_dropdown_item ) ;
		}
		public SimpleSpinner
			( Spinner spinner, int iFirstNum,
			  String[] aTextArray, int[] aNumArray,
			  int resSpinnerItem, SimpleSpinnerListener listener )
		{
			m_aTextArray = aTextArray ;
			m_aNumArray = aNumArray ;
			m_listener = listener ;
			setupSpinner
				( spinner, iFirstNum, resSpinnerItem,
						android.R.layout.simple_spinner_dropdown_item ) ;
		}
		public SimpleSpinner
			( Spinner spinner, int iFirstNum,
			  String[] aTextArray, int[] aNumArray,
			  int resSpinnerItem, int resDropdownItem,
			  SimpleSpinnerListener listener )
		{
			m_aTextArray = aTextArray ;
			m_aNumArray = aNumArray ;
			m_listener = listener ;
			setupSpinner( spinner, iFirstNum, resSpinnerItem, resDropdownItem ) ;
		}

		public void setupSpinner
			( Spinner spinner, int iFirstNum,
			  int resSpinnerItem, int resDropdownItem )
		{
			m_spinner = spinner ;
			m_selection = numToSelection( iFirstNum ) ;
			ArrayAdapter<String>
				adpStyleList = new ArrayAdapter
					( EntisGLS.getMainActivity(), resSpinnerItem, m_aTextArray ) ;
			adpStyleList.setDropDownViewResource( resDropdownItem ) ;
			spinner.setAdapter( adpStyleList ) ;
			if ( (m_selection >= 0) && (m_selection < m_aTextArray.length) )
			{
				spinner.setSelection( m_selection ) ;
			}
			spinner.setOnItemSelectedListener( this ) ;
		}

		protected int numToSelection( int num )
		{
			if ( m_aNumArray == null )
			{
				return  num ;
			}
			for ( int i = 0; i < m_aNumArray.length; i ++ )
			{
				if ( m_aNumArray[i] == num )
				{
					return  i ;
				}
			}
			return  -1 ;
		}

		public Spinner getSpinner()
		{
			return  m_spinner ;
		}

		public int getSelectionIndex()
		{
			return  m_selection ;
		}
		public int getSelectionNum( int ifNonSelected )
		{
			if ( m_aNumArray == null )
			{
				return  m_selection ;
			}
			if ( m_selection >= 0 )
			{
				return  m_aNumArray[m_selection] ;
			}
			return  ifNonSelected ;
		}

		@Override
		public void onItemSelected
			( AdapterView<?> parent, View view, int position, long id )
		{
			if ( (position >= 0) && (position < m_aTextArray.length) )
			{
				m_selection = position ;
				if ( m_listener != null )
				{
					m_listener.onSelected( this, m_selection ) ;
				}
			}
		}

		@Override
		public void onNothingSelected (AdapterView<?> parent)
		{
			m_selection = -1 ;
			if ( m_listener != null )
			{
				m_listener.onSelected( this, m_selection ) ;
			}
		}
	}
}
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?