スピナーのテキストサイズとテキストの色を変更するにはどうすればよいですか?


432

私のAndroidアプリケーションでは、スピナーを使用しており、SQLiteデータベースからスピナーにデータをロードしましたが、それは正常に機能しています。これがそのコードです。

Spinner spinner = (Spinner) this.findViewById(R.id.spinner1);
List<String> list = new ArrayList<String>();
ArrayAdapter<String> dataAdapter = new ArrayAdapter<String>  (this,android.R.layout.simple_spinner_item, list);
cursor.moveToFirst();

list.add("All Lists");

if (cursor.getCount() > 0) {
    for (int i = 0; i < cursor.getCount(); i++) {
        keyList[i] = cursor.getString(cursor.getColumnIndex(AndroidOpenDbHelper.KEYWORD));
        list.add(keyList[i]);
        cursor.moveToNext();
    }
}
Database.close();
cursor.close();
dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner.setAdapter(dataAdapter);

次に、スピナーデータのテキストの色とサイズを変更します。XMLファイルのスピナータグに次のXML行を使用しましたが、機能しません。

android:textColor="@android:color/white"
android:textSize="11dp"

スピナーのテキストの色とサイズを変更するにはどうすればよいですか?


以下のサイト[StackOverflowの] [1] [stackoverflowの] [2] [stackoverflowの] [3]をチェックし、私はこれが重複質問[1]であると思う:stackoverflow.com/questions/4880413/... [2]:stackoverflow.com/questions / 4989817 / ... [3]:stackoverflow.com/questions/5836254/...
user1203673

この投稿をしてみてくださいstackoverflow.com/questions/6159113/...
アジャイ

1
TEXTSIZE =「11SP」:TEXTSIZEの正しいはSP ...アンドロイド使用することです
ディエゴ・ヴェナンシオ

回答:


780

スピナーアイテムのカスタムXMLファイルを作成します。

spinner_item.xml:

このファイルのテキストにカスタマイズした色とサイズを指定します。

<?xml version="1.0" encoding="utf-8"?>

<TextView  
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent" 
    android:layout_height="wrap_content"
    android:textSize="20sp"
    android:gravity="left"  
    android:textColor="#FF0000"         
    android:padding="5dip"
    />

このファイルを使用して、次のようなスピナーアイテムを表示します。

ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, R.layout.spinner_item,list);

ドロップダウンリソースを設定する必要はありません。それは取るspinner_item.xmlだけスピナーであなたの項目を表示します。


2
@Hiralテキストは、現在選択されているアイテムに対してのみ白になります。
テスラ

8
@SANTHOSHは、IDをTextViewに追加する必要がありandroid:id="@+id/customSpinnerItemTextView"ます。そこに追加するだけです。これをデバッグしたなら、あなたはこれを知っているでしょう。
vilpe89 2013年

3
@ vilpe89上記のコードを変更して、これが何を意味するかを示すことができますか?このandroid:idはどこにありますか?独自のIDがあるため、spinnerタグには含まれていません。しかし、上記で作成したtextviewタグに追加しても意味がありません。このタグを使用することをXMLから直接参照するにはどうすればよいですか?また、EclipseからXMLを作成するときに、TextViewのみを含むXMLファイルを作成するオプションが表示されません。それはどのように機能しますか?
マイケル

29
ほんの少しのメモ。テキストサイズはdp / dipの代わりにspを使用する必要があります
ymerdrengene '22

18
スタイルだけでこれを行うことはできませんか?私は、小さなものはアンドロイドでスタイルに非常に困難であるどのように驚いています。これは、私は、彼らが、CSSのようなスタイリングシステムだった望んだ...イライラさせられる
yeahmanを

183

シンプルでさわやかな...:

private OnItemSelectedListener OnCatSpinnerCL = new AdapterView.OnItemSelectedListener() {
    public void onItemSelected(AdapterView<?> parent, View view, int pos, long id) {

       ((TextView) parent.getChildAt(0)).setTextColor(Color.BLUE);
       ((TextView) parent.getChildAt(0)).setTextSize(5);

    }

    public void onNothingSelected(AdapterView<?> parent) {

    }
};

19
スピナーのテキストの色を変更する必要がありましたが、表示されるリストでは変更しなかったため、これは私にとって最良の解決策です。ありがとうございました。
peter.bartos 2012

7
私にとって、アイテムの色が点滅し、元の色から選択した色に変わります
フェリペコンデ

@FelipeConde答えを見つけたことがありますか?同じ質問があります。私の質問はここにある:stackoverflow.com/questions/33908564/...
ロック・リー

@FelipieCondeあなたのために、それは最初に上昇色を取ります、そしてあなたは手動で他の色に変更します、それでそれはとても疲れて見えます。最初にそれはあなたが点滅を感じるので、あなたが手動で、プログラム上で変更された色/ color_primary </アイテム> @ <項目名=「colorAccent」>を取り
アシュラフ

2
これは私にとってはうまくいきましたが、私の問題は、上記のコードでnullポインターを取得してフラグメントアプリがクラッシュするときです
Akshay Shah

145

すべてのスピナーのTextViewアイテムのテキストの色が同じである場合、別のアプローチはスピナードロップダウンアイテムにカスタムスタイルを使用することです。

res/values/styles.xml

<resources>
    <style name="AppBaseTheme" parent="android:Theme.Light">
    </style>

    <style name="AppTheme" parent="AppBaseTheme">
        <item name="android:spinnerDropDownItemStyle">@style/mySpinnerItemStyle</item>
    </style>

    <style name="mySpinnerItemStyle" parent="@android:style/Widget.Holo.DropDownItem.Spinner">
        <item name="android:textColor">@color/my_spinner_text_color</item>
    </style>
</resources>

そして、カスタム色をres / values / colors.xmlで定義します。

<color name="my_spinner_text_color">#808080</color>

2
そして、このソリューションをAppcomptテーマに適用する方法は?親テーマ "@ style / Widget.AppCompat.DropDownItem.Spinner"をオーバーライドして試してみましたが、うまくいきませんでした
GyRo

11
次も追加します:<item name = "android:spinnerItemStyle"> @ style / mySpinnerItemStyle </ item>これにより、折りたたまれたテキストが同じ色になるようになります-これが望ましい動作である場合に備えて。
無限ループ、

4
私にとっても機能しない、スタイルは完全に無視される
diogo.abdalla

1
@Whypeeは、完璧に機能する無限ループの提案に従って、回答を編集してください
Chintan Desai

4
AppCompatテーマの場合は、次のandroid:ように削除します<item name="spinnerDropDownItemStyle">@style/mySpinnerItemStyle</item>
Roman_D

73

以下は、スピナーの色変更するのに役立つリンクです。

ここをクリック

<Spinner
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:id="@+id/spinner"
    android:textSize="20sp"
    android:entries="@array/planets"/>

スピナーアイテムspinner_item.xmlのカスタム定義を使用して、独自のレイアウトファイルを作成する必要があります。

<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/text1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textSize="20sp"
    android:textColor="#ff0000" />

ドロップダウンリストの項目をカスタマイズする場合は、新しいレイアウトファイルを作成する必要があります。spinner_dropdown_item.xml

<?xml version="1.0" encoding="utf-8"?>
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/text1"
    style="?android:attr/spinnerDropDownItemStyle"
    android:maxLines="1"
    android:layout_width="match_parent"
    android:layout_height="?android:attr/listPreferredItemHeight"
    android:ellipsize="marquee"
    android:textColor="#aa66cc"/>

そして最後に、スピナーの宣言の別の変更:

ArrayAdapter adapter = ArrayAdapter.createFromResource(this,
R.array.planets_array, R.layout.spinner_item);

adapter.setDropDownViewResource(R.layout.spinner_dropdown_item);
spinner.setAdapter(adapter);

それでおしまい。


2
これは、新しいユーザーによる投稿のレビューからの自動応答でした。回答を編集したことをうれしく思います!:)
マルコ

1
その、思わandroid:textSize="20sp"制御のTEXTSIZEは、で定義されている:最初のコードスニペットでは役に立たないspinner_item.xml
DenisGL

23

android.support.v7.widget.AppCompatSpinnerを使用する場合、スタイルを使用した最も簡単なテスト済みソリューションは次のとおりです。

 <android.support.v7.widget.AppCompatSpinner
                    android:id="@+id/spefcialFx"
                    style="@style/Widget.AppCompat.Spinner.Underlined"
                    android:layout_width="200dp"
                    android:layout_height="wrap_content"
                    android:layout_marginLeft="4dp"
                    android:theme="@style/Spinner"
                    android:entries="@array/special_fx_arrays"
                    android:textSize="@dimen/text_size_normal"></android.support.v7.widget.AppCompatSpinner>

そしてスタイル:

<style name="Spinner" parent="Widget.AppCompat.Light.DropDownItem.Spinner">
        <item name="android:paddingStart">0dp</item>
        <item name="android:paddingEnd">0dp</item>
        <item name="android:textColor">@color/white</item>
        <item name="android:backgroundTint">@color/red</item>
        <item name="android:textSize">14sp</item>
    </style>

唯一の欠点は、android:backgroundTintがドロップダウン矢印とドロップダウン背景の両方の色を設定することです。


3
使用しているstyle="@style/Widget.AppCompat.Spinner.Underlined"が、使用できるのはstyle name="Spinner"... のみ
user25

1
paddingStartAPI 17を必要とし、backgroundTintAPI 21を必要とする
CoolMind

18

遅れを防ぐには、onItemSelectedリスナーのテキストプロパティだけでなく、アクティビティのテキストプロパティも設定する必要があります。onCreateメソッドで(ただし、少し注意が必要です)。

具体的にはonCreate、アダプターの設定後にこれを配置する必要があります。

spinner.setSelection(0, true);
View v = spinner.getSelectedView();
((TextView)v).setTextColor(backgroundColor);

そしてこれを入れますonItemSelected

((TextView) view).setTextColor(backgroundColor);

ここに完全な例があります:

@Override  
protected void onCreate(Bundle savedInstanceState)
{  
    Spinner spinner = (Spinner) findViewById(R.id.spinner); 

    //Set the choices on the spinner by setting the adapter.  
    spinner.setAdapter(new SpinnerAdapter(toolbar.getContext(), new String[]{"Overview", "Story", "Specifications", "Poll", "Video"}, accentColor, backgroundColor));

    //Set the text color of the Spinner's selected view (not a drop down list view) 
    spinner.setSelection(0, true);
    View v = spinner.getSelectedView();
    ((TextView)v).setTextColor(backgroundColor);

    //Set the listener for when each option is clicked.  
    spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener()
    {  

        @Override  
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id)
        {  
           //Change the selected item's text color  
           ((TextView) view).setTextColor(backgroundColor);
        }  

        @Override  
        public void onNothingSelected(AdapterView<?> parent)
        {  
        }  
    });  

}  

詳細については、私の質問を参照しください。


15

選択したアイテムでのみテキストの色を変更する場合は、これが回避策となります。それは私にとってはうまくいき、あなたにとってもうまくいくはずです。

spinner.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
            @Override
            public void onGlobalLayout() {
                ((TextView) spinner.getSelectedView()).setTextColor(Color.WHITE);
            }
        });

6

のためだけのStyle方法が必要な人のためにAppCompat

結果
ここに画像の説明を入力してください ここに画像の説明を入力してください

styles.xml

<resources>
    ... 
    <style name="Spinner" parent="Widget.AppCompat.Light.DropDownItem.Spinner">
        <item name="android:paddingStart">0dp</item>
        <item name="android:paddingEnd">0dp</item>
        <item name="android:textColor">@color/material_grey_700</item>
        <item name="android:textSize">12sp</item>
    </style>
</resources>

your_spinner_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />
    ...

    <android.support.v7.widget.AppCompatSpinner
        android:id="@+id/content_spinner"
        style="@style/Widget.AppCompat.Spinner.Underlined"
        android:layout_width="140dp"
        android:layout_height="wrap_content"
        android:entries="@array/shipping_tracking_carrier_names"
        android:spinnerMode="dropdown"
        android:theme="@style/Spinner" />

    <EditText
        android:id="@+id/content_input"
        android:layout_width="140dp"
        android:layout_height="wrap_content"
        android:inputType="text"
        android:maxLines="1"
        android:paddingEnd="8dp"
        android:paddingStart="8dp"
        android:textColor="@color/material_grey_700"
        android:textSize="12sp" />

    ...
</LinearLayout>    

さらに、定義されたスタイルでプログラムで
設定したい場合android:entries
これを試して。

AppCompatSpinner spinner = findViewById(R.id.content_spinner);
CharSequence[] entries = getResources().getTextArray(R.array.shipping_tracking_carrier_names);
ArrayAdapter<CharSequence> adapter = new ArrayAdapter<>(spinner.getContext(), android.R.layout.simple_spinner_item, entries);
adapter.setDropDownViewResource(android.support.v7.appcompat.R.layout.support_simple_spinner_dropdown_item);
spinner.setAdapter(adapter);

コードと同様Contextに、Spinnerと同じように使用することが最も重要です。

spinner.getContext()

5

スピナーテキストの色を変更するには:

 public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
            ((TextView) parent.getChildAt(0)).setTextColor(Color.WHITE);}

これが最も簡単で、うまくいきました。
Mousa Alfhaily

私もこの解決策が好きです。シンプルでうまく機能します。
korchix

4

カスタムレイアウトを作成して小さいサイズを取得するのではなく、スピナーにAndroidの内部の小さいサイズのLAYOUTを使用する場合は、以下を使用する必要があります。

「android.R.layout.simple_spinner_item」の代わりに「android.R.layout.simple_gallery_item」。

ArrayAdapter<CharSequence> madaptor = ArrayAdapter
            .createFromResource(rootView.getContext(),
                                R.array.String_visitor,
                                android.R.layout.simple_gallery_item);

スピナーのレイアウトのサイズを縮小できます。それは単なるトリックです。

ドロップダウンリストのサイズを小さくしたい場合は、これを使用してください:

madaptor.setDropDownViewResource(android.R.layout.simple_gallery_item);

4

android.R.layoutリソースを再利用/変更する最も簡単な方法は、定義に従うことです。Android Studioで、android.R.layout.simple_spinner_item.xmlでCtrl+ Bを実行します。

リソースファイルに移動します。リソースファイルをコピーしてPackage.R.layoutフォルダーに新しいレイアウトを追加し、textviewのtextColorを好きなように変更して、次のようにアダプターで呼び出すだけです。

ArrayAdapter<String> adapter = new ArrayAdapter<String(Context,R.layout.spinner_item, spinnerlist);

4

DrowDownIcon色を変えたい方はこんな風に使えます

spinner.getBackground().setColorFilter(Color.parseColor("#ffffff"), PorterDuff.Mode.SRC_ATOP);

あなたは試すことができます<item name="android:colorControlNormal" tools:targetApi="lollipop">@color/light_gray</item>
AMAN SINGH 2017

このラインをあなたのスタイルにAppTheme
AMAN SINGH

これが機能したコードですDrawable spinnerDrawable = spinner.getBackground().getConstantState().newDrawable(); spinnerDrawable.setColorFilter(getResources().getColor(R.color.md_white_1000), PorterDuff.Mode.SRC_ATOP); if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) { spinner.setBackground(spinnerDrawable); }else{ spinner.setBackgroundDrawable(spinnerDrawable); }
Edijae Crusar 2017

4

次のようにgetViewメソッドをオーバーライドすることにより、テキストの色を変更できます。

 new ArrayAdapter<String>(getContext(), android.R.layout.simple_spinner_dropdown_item, list()){
                @Override
                public View getView(int position, View convertView, @NonNull ViewGroup parent) {
                    View view = super.getView(position, convertView, parent);
                    //change the color to which ever you want                    
                    ((CheckedTextView) view).setTextColor(Color.RED);
                    //change the size to which ever you want                    
                    ((CheckedTextView) view).setTextSize(5);
                    //for using sp values use setTextSize(TypedValue.COMPLEX_UNIT_SP, 16);
                    return view;
                }
    }


2
<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@android:id/text1"
    style="?android:attr/spinnerItemStyle"
    android:singleLine="true"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textColor="#fff"
    android:ellipsize="marquee"
    android:textAlignment="inherit"/>

これを使うだけです:

ArrayAdapter<String> adapter_category = new ArrayAdapter<String>(this,
    R.layout.spinner_list_item, categories);
adapter_category
    .setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

1

Ashrafのソリューションのもう1つのバリエーションは、画面サイズを考慮に入れることです。アダプタを設定した後、スピナーをonCreateで取得し、リスナーを設定する必要があります。

//set your adapter with default or custom spinner cell, then://
serverSpinner.setOnItemSelectedListener(spinnerSelector);
serverSpinner.setSelection(defaultServer);

次に、スピナーがクリックされる前に表示されるビューのテキストサイズの変更を開始できます。

private AdapterView.OnItemSelectedListener spinnerSelector = new AdapterView.OnItemSelectedListener() {
    public void onItemSelected(AdapterView<?> parent, View view, int pos, long id) {
        boolean tabletSize = getResources().getBoolean(R.bool.isTablet);
        boolean largeTablet = getResources().getBoolean(R.bool.isLargeTablet);
        if (tabletSize) { ((TextView)parent.getChildAt(0)).setTextSize(16); }
        else if (largeTablet) { ((TextView)parent.getChildAt(0)).setTextSize(18); }
        else { ((TextView)parent.getChildAt(0)).setTextSize(12); }
    }
    public void onNothingSelected(AdapterView<?> parent) {

    }
};

必要なのは、次のようなレイアウト固有のフォルダーを作成することだけです。

values-sw360dp

values-sw600dp

values-sw800dp

次に、「bool.xml」という名前のxmlファイルをこれらの各フォルダーに追加します。

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <bool name="isTablet">false</bool>
    <bool name="isLargeTablet">false</bool>
</resources>

1

まず、以下xmltextviewような単純なリソースファイルを作成する必要があります。

<?xml version="1.0" encoding="utf-8"?>

 <TextView  
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent" 
    android:layout_height="wrap_content"
    android:textSize="20sp"
    android:gravity="left"  
    android:textColor="#FF0000"         
    android:padding="5dip"
    />   

それを保存します。あなたのadapterlistに設定した後。


1

このタイプのスピナー用アダプターは、完全にカスタマイズできます。

 ArrayAdapter<String> genderAdapter = new ArrayAdapter<String>(getActivity(), R.layout.spinner_text, genderList) {

        public View getView(int position, View convertView, ViewGroup parent) {
            View v = super.getView(position, convertView, parent);
            ((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
            ((TextView) v).setTextColor(Color.parseColor("#676767"));
            ((TextView) v).setTypeface(vrFont);
            return v;
        }

        public View getDropDownView(int position, View convertView, ViewGroup parent) {
            View v = super.getDropDownView(position, convertView, parent);
            ((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
            ((TextView) v).setTypeface(vrFont);
            ((TextView) v).setTextColor(Color.parseColor("#676767"));

            if (position == 0) {
                ((TextView) v).setTextColor(Color.parseColor("#979797"));
            }

            return v;
        }

一方、R.layout.spinner_textは次のとおりです。

<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/text1"
style="?android:attr/spinnerItemStyle"
android:layout_width="fill_parent"
android:layout_height="40dp"
android:gravity="center_vertical|left"
android:ellipsize="marquee"
android:maxLines="1"
android:textColor="@color/whiteThree" />

1

単純なメソッドが必要な場合は、アイテムをドロップダウンに追加するために、通常それらをstrings.xmlに追加します。次に、strings.xmlファイルを使用して色を追加する方法の例を示します。

年齢層を選択

<string-array name="age_array">

   <item> 0-6 </item>                               //No custom colour

  <item><font fgcolor='#FF4CD964'> 12+ </font></item> //With custom colour

</string-array>

かわいいトリック... 1回限りのスピナーでは便利で高速です。色はxmlからではなく生の色値文字列である必要があります
me_

0

これを次のように実行しました。getDropDownView()およびgetView()メソッドを使用しています。

getDropDownView()開いたスピナーに使用します。

@Override
public View getDropDownView(int position, View convertView, ViewGroup parent) {
  View view = convertView;
  if (view == null) {
    LayoutInflater vi = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    view = vi.inflate(R.layout.context_row_icon, null);
  }
  TextView mTitle = (TextView) view.findViewById(R.id.context_label);
  ImageView flag = (ImageView) view.findViewById(R.id.context_icon);                

  mTitle.setText(values[position].getLabel(activity));

  if (!((LabelItem) getItem(position)).isEnabled()) {
    mTitle.setTextColor(activity.getResources().getColor(R.color.context_item_disabled));
  } else {
    mTitle.setTextColor(activity.getResources().getColor(R.color.context_item));
  }
  return view;
}

そしてgetView()、閉じたスピナーに使用します。

@Override
public View getView(int position, View convertView, ViewGroup parent) {
  View view = convertView;
  if (view == null) {
    LayoutInflater vi = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    view = vi.inflate(R.layout.context_row_icon, null);
  }
  TextView mTitle = (TextView) view.findViewById(R.id.context_label);
  ImageView flag = (ImageView) view.findViewById(R.id.context_icon);

  mTitle.setText(values[position].getLabel(activity));
  mTitle.setTextColor(activity.getResources().getColor(R.color.context_item_disabled));

  return view;
}

これは適切にテストされたコードであり、appstoreのアプリケーションで動作します
Bhavinkumar Patel

0

この方法を試してください。それは私のために働いています。

@Override
public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l) {
    TextView textView = (TextView) view;
    ((TextView) adapterView.getChildAt(0)).setTextColor(Color.RED);
    ((TextView) adapterView.getChildAt(0)).setTextSize(20);
    Toast.makeText(this, textView.getText()+" Selected", Toast.LENGTH_SHORT).show();
}

0

このような新しいスタイルを追加するだけです:

<style name="mySpinnerItemStyle" parent="ThemeOverlay.AppCompat.Dark">
    <item name="android:textColor">#000</item>
    <item name="android:color">#000</item>
</style>

そしてそれを使う:

<Spinner
      android:id="@+id/spinnerCategories"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      style="@style/mySpinnerItemStyle"
      android:layout_margin="5dp" />

0
    String typeroutes[] = {"Select","Direct","Non Stop"};
    Spinner typeroute;

    typeroute = view.findViewById(R.id.typeroute);

    final ArrayAdapter<String> arrayAdapter5 = new ArrayAdapter<String>(
                getActivity(), android.R.layout.simple_spinner_item, typeroutes) {
            @Override
            public boolean isEnabled(int position) {
                if (position == 0) {
                    // Disable the first item from Spinner
                    // First item will be use for hint
                    return false;
                } else {
                    return true;
                }
            }

            public View getView(int position, View convertView, ViewGroup parent) {
                View v = super.getView(position, convertView, parent);
                ((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
                ((TextView) v).setTextColor(Color.parseColor("#ffffff"));
                return v;
            }         ---->in this line very important so add this

            @Override
            public View getDropDownView(int position, View convertView,
                                        ViewGroup parent) {
                View view = super.getDropDownView(position, convertView, parent);
                TextView tv = (TextView) view;
                if (position == 0) {
                    // Set the hint text color gray
                    tv.setTextColor(Color.GRAY);
                } else {
                    tv.setTextColor(Color.BLACK);
                }
                return view;
            }
        };

        arrayAdapter5.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

        typeroute.setAdapter(arrayAdapter5);

それはあなたのコーディングを楽しむすべてです...

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.