четверг, 20 октября 2011 г.

Свой SeekBar

Если по какой-то причине Вас не устраивает вид стандартных элементов управления, никто не мешает создавать свои. Например, изменим стандартный SeekBar:

1. В папке layout создадим xml-файл, допустим progress.xml, в который напишем следующее:


<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:id="@android:id/background">
        <shape>
            <corners android:radius="5dip" />
            <gradient
                    android:startColor="#ff00ff00"
                    android:centerColor="#ff000000"
                    android:centerY="0.5"
                    android:endColor="#ff00ff00"
                    android:angle="270"
            />
        </shape>
    </item>
    <item android:id="@android:id/secondaryProgress">
        <clip>
            <shape>
                <corners android:radius="5dip" />
                <gradient
                        android:startColor="#80ffd300"
                        android:centerColor="#80ffb600"
                        android:centerY="0.75"
                        android:endColor="#a0ffcb00"
                        android:angle="270"
                />
            </shape>
        </clip>
    </item>

    <item android:id="@android:id/progress">
        <clip>
            <shape>
                <corners android:radius="5dip" />
                <gradient
                        android:startColor="#ffff0000"
                        android:centerColor="#ff000000"
                        android:centerY="0.5"
                        android:endColor="#ffff0000"
                        android:angle="270"
                />
            </shape>
        </clip>
    </item>
</layer-list>

Это сам SeekBar. Теперь ползунок для него, опять же xml (пусть будет progress_t.xml):


<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true"
          android:state_window_focused="true"
          android:drawable="@drawable/sb"/>
    <item android:state_focused="true"
          android:state_window_focused="true"
          android:drawable="@drawable/sb"/>
    <item android:state_selected="true"
          android:state_window_focused="true"
          android:drawable="@drawable/sb"/>
    <item android:drawable="@drawable/sb"/>
</selector>

Тут sb - это картинка, изображающая ползунок, на Ваш вкус. Ну и наконец в main.xml пишем:


       <SeekBar
        android:id="@+id/seekbar1"
        android:layout_height="wrap_content"
        android:layout_width="fill_parent"
        android:fadingEdge="none"
        android:thumb="@layout/progress_t"
        android:progressDrawable="@layout/progress"
        android:scrollbarStyle="outsideInset" >
        </SeekBar>


На выходе имеем следующее:



Комментариев нет:

Отправить комментарий