1

2 つの NumberPicker を使用してダイアログを作成しようとしています。デフォルトの Holo テーマ スタイルにしたいと思います。良い例が見つかりません。これまでのところ、私は得ました:

    LayoutInflater inflater = (LayoutInflater)
        getApplicationContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        View npView = inflater.inflate(R.layout.number_picker_dialog, null);
        NumberPicker minPicker = (NumberPicker) npView.findViewById(R.id.min_picker);
        minPicker.setMaxValue(100);
        minPicker.setMinValue(0);
        NumberPicker maxPicker = (NumberPicker) npView.findViewById(R.id.max_picker);
        maxPicker.setMaxValue(100);
        maxPicker.setMinValue(0);

        AlertDialog.Builder builder = new AlertDialog.Builder(this);
        builder.setTitle("Text Size:");
        builder.setView(npView);
        builder.setPositiveButton("Okay",
            new DialogInterface.OnClickListener() {
                public void onClick(DialogInterface dialog, int whichButton) {

                }
            });
       builder.setNegativeButton("Cancel",
                new DialogInterface.OnClickListener() {
                    public void onClick(DialogInterface dialog, int whichButton) {
                    }
                });
       dialog = builder.create();
       dialog.show();

number_picker_dialog xml:

 <?xml version="1.0" encoding="utf-8"?>
 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:holo="http://schemas.android.com/apk/res-auto"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="horizontal" 
 android:gravity="center">

<NumberPicker 
    android:id="@+id/min_picker"
    android:width="100dip"
    android:layout_height="wrap_content"
    android:layout_width="wrap_content"
    android:/>

<NumberPicker 
    android:id="@+id/max_picker"
    android:width="100dip"
    android:layout_height="wrap_content"
    android:layout_width="wrap_content"/>

</LinearLayout>

しかし、カラーピッカーのテキストは (背景のように) 白く、NumberPicker の textColor を設定できません。

どうすれば textColor を設定できますか、または誰かが NumberPicker の良い例を知っていますか?

4

3 に答える 3

1

私の NumberPicker が Holo.Light スタイルではない理由を見つけました:

呼び出す代わりに:

   LayoutInflater inflater = (LayoutInflater) this.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
   View npView = inflater.inflate(R.layout.number_picker_dialog, null);

私はそれを呼び出して解決しました:

 View npView = getLayoutInflater().inflate(R.layout.number_picker_dialog, null);
于 2012-12-17T14:33:04.660 に答える
0

試す :

<NumberPicker
    style="@android:style/TextAppearance">
</NumberPicker>
于 2012-12-14T18:48:35.870 に答える
0

私のアプローチは、以下に示すようにカスタム ダイアログ クラスを作成することでした。

public class CustomDialog extends Dialog {
     public CustomDialog(Context context) {
        super(context, R.style.customDialog); //use your style id from styles.xml
     }

     public void setNumberDialog() {
          setContentView(R.layout.number_picker_dialog);
          //add required listeners
          show();
     }
}

Activity の呼び出しからダイアログを呼び出します。

 new CustomDialog(context).setNumberDialog(); 

スタイル パラメータは、styles.xml で定義されます。

<style name="customDialog" parent="android:Theme.Dialog">
    <item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
    <item name="android:windowSoftInputMode">stateUnspecified|adjustPan</item>
    <item name="android:background">@android:color/transparent</item>
    <item name="android:textColor">@color/textColorWhite</item>
</style>
于 2012-12-14T16:49:57.727 に答える