如何在android中设置一个可绘制的形状:seekbar中的progressDrawable(形状大小在< 21 api中删除,在> = 21 api中增加)

时间:2016-06-03 06:50:39

标签: android android-layout xml-drawable

我有一个视图(Seekbar),我在progressDrawable中设置了一个名为seek_bar.xml的可绘制形状,但是当我在不同级别的api中运行布局时,我得到了不同的结果。意味着当我在< 21中运行布局时,形状尺寸看起来太小但是当我运行布局> = 21形状尺寸看起来很完美时,请帮我解决这个布局的api级问题。看图像。

我的appcompct版本是。

compile 'com.android.support:appcompat-v7:23.1.1'

<21 api level layout look >=21 api level looks perfect

我有一个名为confirm.xml的视图代码

    <LinearLayout
    android:layout_centerInParent="true"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:background="@drawable/dialog_background"
    android:orientation="vertical"
    xmlns:android="http://schemas.android.com/apk/res/android">

    <TextView
        android:id="@+id/txt_dia"
        android:layout_width="fill_parent"
        android:layout_height="0dp"
        android:layout_gravity="center"
        android:layout_marginBottom="10dp"
        android:layout_marginTop="40dp"
        android:layout_weight="1"
        android:gravity="center_horizontal"
        android:paddingLeft="10dp"
        android:paddingRight="10dp"
        android:text="@string/dialog_title_logout"
        android:textColor="@color/gray_dark"
        android:textSize="@dimen/dialog_text_title"
        android:textStyle="bold"
        >
    </TextView>

    <RelativeLayout
        android:id="@+id/yes_no_back_strip"
        android:layout_width="match_parent"
        android:layout_height="70dp"
        android:layout_below="@+id/swipe_btn"
        android:layout_marginBottom="15dp"
        android:layout_marginLeft="10dp"
        android:layout_marginRight="10dp"
        >

        <SeekBar
            android:id="@+id/unlockButton"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:clickable="false"
            android:max="100"
            android:progress="50"
            android:thumb="@drawable/slide_thumb"
            android:splitTrack="false"
            android:paddingLeft="1dp"
            android:paddingRight="1dp"
            android:thumbOffset="1dp"
            android:paddingTop="5dp"
            android:paddingBottom="5dp"
            android:progressDrawable="@drawable/seek_bar"
            />

        <LinearLayout
            android:id="@+id/yes_no_layout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_marginBottom="10dp"
            android:layout_marginTop="10dp"
            android:orientation="horizontal"
            android:visibility="visible"
            >

            <TextView
                android:id="@+id/confirm_btn"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:layout_centerVertical="true"
                android:layout_gravity="center"
                android:layout_weight="1"
                android:gravity="left|center_vertical"
                android:paddingLeft="15dp"
                android:text="@string/btn_txt_yes"
                android:textColor="@color/gray_light_high"
                android:textSize="@dimen/common_text_size"
                android:textStyle="bold"
                />

            <TextView
                android:id="@+id/cancel_btn"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:layout_centerVertical="true"
                android:layout_gravity="center"
                android:layout_weight="1"
                android:gravity="right|center_vertical"
                android:paddingRight="15dp"
                android:text="@string/btn_txt_no"
                android:textColor="@color/gray_light_high"
                android:textSize="@dimen/common_text_size"
                android:textStyle="bold"
                />
        </LinearLayout>

    </RelativeLayout>

</LinearLayout>

我的seek_bar.xml是....

     <?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:id="@android:id/background">
        <shape>

            <gradient
                android:angle="0"
                android:startColor="#ffe0db"
                android:centerColor="#aeff6960"
                android:endColor="#ff0002"
                />
            <corners android:radius="35dip" />
            <size android:height="49dp"
                  android:width="190dp"/>
        </shape>
    </item>
    <item android:id="@android:id/progress">
        <clip >
            <shape>
                <gradient
                    android:angle="0"
                    android:startColor="#0b6e07"
                    android:centerColor="#75ba70"
                    android:endColor="#97ba93"
                   />
                <corners android:radius="35dp"
                    />
                <size android:height="49dp"
                      android:width="190dp"/>
            </shape>
        </clip>
    </item>
</layer-list>

2 个答案:

答案 0 :(得分:1)

在api级别&gt; 20 android:width和android:height不适用于形状,我的意思是它会根据视图自动检测正确的高度和宽度,但是当你使用api级别时它并非如此; 20。因此,当您修复最小宽度和高度时,它将在所有api级别中保持固定。 否则,您可以指定不同的-2布局大小。 只需在搜索栏布局中添加minHight和maxHight

<Seekbar
    .....
    android:minHeight="50dp"
    android:maxHeight="50dp"
    ....
 />

答案 1 :(得分:0)

希望这对所有API都有帮助:

<Seekbar
    .....
    android:background="@null"
    android:splitTrack="false"
    ....
 />