Androidアプリのシークバーを作成して、ユーザーが-5から5までの値を選択できるようにします(「強く同意しない」と「強く同意する」にマップされます)。離散値でシークバーを作成しますか?これに使用できるより優れたUIウィジェットはありますか?
ありがとう。
シークバーは離散値に最適です。以下に示すように、離散データにはシークバーを使用します。選択されているアイテムを表示するには、選択されたテキストビューのフォントを大きくするだけです。背景色などを変更してハイライトすることもできます。それはかなりうまくいきます。シークバーでsetMax(11)を呼び出し、コード内で範囲(0〜11)と(-5〜5)を適切に変換する必要があります。
<LinearLayout
Android:orientation="vertical"
Android:layout_width="fill_parent"
Android:layout_height="wrap_content"
Android:gravity="center_horizontal">
<LinearLayout
Android:orientation="horizontal"
Android:layout_width="fill_parent"
Android:layout_height="wrap_content"
Android:gravity="center_horizontal">
<TextView Android:text="-5"
Android:id="@+id/answerNegative5"
Android:textSize="25sp"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content" />
<TextView Android:text="-4"
Android:id="@+id/answerNegative4"
Android:textSize="25sp"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content" />
<TextView Android:text="-3"
Android:id="@+id/answerNegative3"
Android:textSize="25sp"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content" />
.....
</LinearLayout>
<SeekBar Android:id="@+id/intensitySlider"
Android:layout_weight="0"
Android:layout_width="fill_parent"
Android:layout_height="wrap_content" />
</LinearLayout>
このリンクを確認してください サードパーティのライブラリを使用せずに、ギャップのある離散シークバーを実装する場合は、シークバーのスタイルプロパティを使用します。
<SeekBar
Android:id="@+id/sb"
Android:layout_width="match_parent"
Android:layout_height="wrap_content"
Android:max="10"
Android:thumb="@drawable/ic_location"
Android:theme="@style/Widget.AppCompat.SeekBar.Discrete" />
ここでは何が問題なのかわかりません。0〜10の範囲のシークバーを追加します。次に、選択した値から-5を引くと、これらの値を-5にマッピングできます。
[〜#〜]編集[〜#〜]
追加 Android:max="10"
をxml定義に追加すると、固定サイズのシークバーが表示されます。
次のような現在選択されている値のテキスト表現を示すために、テキストビューを追加することを検討する必要があります。このビューを更新するには、onProgressChanged
イベントをサブスクライブします。progress
パラメータを使用すると、選択した番号が表示されます。
SeekBar s = (SeekBar) findViewById(R.id.SeekBar);
s.setOnSeekBarChangeListener(new OnSeekBarChangeListener() {
@Override
public void onProgressChanged(SeekBar seekBar,
int progress, boolean fromUser) {
}
}
このコードがきっとあなたのお役に立てば幸いです。これを試して...
float discrete = 0;
float start = 0;
float end = 100;
float start_pos = 0;
int start_position = 0;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
start = -10; //you need to give starting value of SeekBar
end = 10; //you need to give end value of SeekBar
start_pos = 5; //you need to give starting position value of SeekBar
start_position = (int)(((start_pos - start) / (end - start)) * 100);
discrete = start_pos;
SeekBar seek = (SeekBar) findViewById(R.id.seekBar1);
seek.setProgress(start_position);
seek.setOnSeekBarChangeListener(new OnSeekBarChangeListener() {
@Override
public void onStopTrackingTouch(SeekBar seekBar) {
// TODO Auto-generated method stub
Toast.makeText(getBaseContext(), "discrete = " + String.valueOf(discrete), Toast.LENGTH_SHORT).show();
}
@Override
public void onStartTrackingTouch(SeekBar seekBar) {
// TODO Auto-generated method stub
}
@Override
public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
// TODO Auto-generated method stub
// To convert it as discrete value
float temp = progress;
float dis = end - start;
discrete = (start + ((temp / 100) * dis));
}
});
}
最初のステップ:maxValを10に設定します。
2番目のステップ:
@Override
public void onProgressChanged(SeekBar seekBar, int progress,
boolean fromUser)
{
switch(seekBar.getId())
{
case R.id.mySeekBar:
int prValue = progress - 5;
editText.setText(String.valueOf(preValue));
break;
}
}
<SeekBar
Android:id="@+id/seekbar"
style="@style/SeekBarWithoutSteps"
Android:layout_width="match_parent"
Android:layout_height="wrap_content"
Android:layout_marginLeft="22dp"
Android:layout_marginRight="22dp"
Android:layout_marginTop="@dimen/margin_10"
Android:max="4"
Android:maxHeight="@dimen/margin_5"
Android:minHeight="@dimen/margin_5"
Android:paddingLeft="@dimen/margin_10"
Android:paddingRight="@dimen/margin_10"
Android:progressBackgroundTint="@color/colorGray"
Android:progressTint="@color/colorGreen"
Android:theme="@style/Widget.AppCompat.SeekBar.Discrete"
Android:thumb="@drawable/filled_green"
Android:thumbOffset="15dp" />