可通过位图绘制

时间:2018-07-20 11:20:01

标签: android android-layout android-view android-xml

您好,我正在尝试实现这种外观,但没有成功,也许您可​​以帮助我,谢谢您的时间!

所需外观:

enter image description here

我的方法是

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

            <gradient
                android:angle="45"
                android:endColor="#cf6c6c6c"
                android:startColor="#53414141"/>
            <corners
                android:bottomLeftRadius="10dp"
                android:bottomRightRadius="10dp"
                android:topRightRadius="10dp"
                />
        </shape>
    </item>


    <item android:gravity="right"
        android:height="10dp"
        android:width="10dp">
        <bitmap android:src="@drawable/flag_uk"/>
    </item>
</layer-list>

2 个答案:

答案 0 :(得分:0)

             

        <gradient
            android:angle="45"
            android:endColor="#cf6c6c6c"
            android:startColor="#53414141"/>
        <corners
            android:bottomLeftRadius="10dp"
            android:bottomRightRadius="10dp"
            android:topRightRadius="10dp"
            />
    </shape>
</item>


<item android:gravity="right|center_vertical"
    android:height="10dp"
    android:width="10dp">
    <bitmap android:src="@drawable/flag_uk"/>
</item>

<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="@drawable/some_drawable"
    android:text="coin"
    android:paddingStart="10dp"
    android:paddingEnd="20dp"
    android:paddingTop="2dp"
    android:paddingBottom="2dp"
    android:layout_margin="10dp"/>

enter image description here照片被缩放,因此被像素化了

答案 1 :(得分:0)

请尝试以下可绘制的xml代码:

可绘制文件:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item
        android:right="25dp">
        <shape
            android:shape="rectangle">
            <corners android:bottomLeftRadius="10dp"
                android:bottomRightRadius="10dp"
                android:topRightRadius="10dp"/>
            <gradient
                android:angle="45"
                android:endColor="#cf6c6c6c"
                android:startColor="#53414141"/>
        </shape>
    </item>
    <item
        android:top="10dp"
        android:left="90dp"
        android:bottom="10dp"
        android:right="15dp">
        <bitmap android:src="@drawable/flag_uk"/>
    </item>

</layer-list>

并将此可绘制对象用于TextViewLinearLayout,我正在使用LinearLayout:

布局XML文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    tools:context=".MainActivity"
    android:background="#88ffffff"
    android:orientation="vertical"
    android:gravity="center">
 <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/button"
        android:paddingLeft="20dp"
        android:paddingRight="40dp"
        android:gravity="center_vertical">
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="coin"
            android:textColor="#ffffff"
            android:textSize="25sp"/>
    </LinearLayout>
</LinearLayout>

**输出:*

enter image description here