如何在android中创建像Iphone Edittext框一样的Gradient

Ami*_*mar 3 xml android android-layout

这是iPhone EditText控件的一个例子:

在此输入图像描述

如何在Android中创建相同的控件?

Spa*_*rky 37

三种EditText背景

基本上,我看到三种方法可以做你想要的.

第一种方法:

第一个是,正如Akki所说,制作一个9补丁,它完全复制了你想要使用的渐变填充框(未指定的其他平台).这使您的应用程序在两个平台上看起来尽可能接近完全相同.

这是一个由上面的屏幕截图制作的9补丁.(这是res/drawable-*dpi/rounded_text_field.9.png)

九贴片背景

第二种方法:

第二种是使用可缩放的原生绘图功能获得相同的效果.这看起来并不完全相同,但可以提供更平滑的结果.

下面是一些使用渐变填充生成圆角矩形图像的代码.(这是res/drawable/gradientbg.xml)

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
android:shape="rectangle"
>
<corners android:radius="8dp"/>
<stroke android:width="2dp"
    android:color="#444"/>
<gradient 
   android:startColor="#888"
   android:centerColor="#fff"
   android:endColor="#fff"
   android:type="linear"
   android:angle="270"
   />
</shape>
Run Code Online (Sandbox Code Playgroud)

实际上,我撒了谎.在我原来的屏幕截图中,角落太大了,所以我将角半径从16dp缩小到8dp.这就是现在的样子.很多改进,你不觉得吗?比调整4种不同密度的位图容易得多.

具有8dp半径角的渐变背景.

第三种方法:

第三种方法是让平台成为它的意图,并在自己的范例内看起来最好.这样做的好处是,在不同版本的操作系统上,即使系统主题发生变化,您的应用程序也会与系统的其他部分无缝融合.

这是默认情况下EditText在Gingerbread上运行完全相同的代码.它在Holo主题设备上看起来很不合适(例如我用来创建第一个屏幕截图的Jellybean驱动的平板电脑),反之亦然.

Gingerbread上的EditText

作为参考,这是包含所有三个EditTexts的布局.

<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"
android:layout_margin="32dp"
android:orientation="vertical"
 >
<EditText
    android:id="@+id/editText1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="24dp"
    android:layout_marginTop="24dp"
    android:padding="12dp"
    android:gravity="center"
    android:background="@drawable/rounded_text_field"
    android:inputType="text"
    android:textColor="@android:color/black"
    android:text="9-patch background." >
    <requestFocus />
</EditText>
<EditText
    android:id="@+id/editText2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="24dp"
    android:layout_marginTop="24dp"
    android:padding="12dp"
    android:gravity="center"
    android:background="@drawable/gradientbg"
    android:inputType="text"
    android:textColor="@android:color/black"
    android:text="Gradient background." />
<EditText
    android:id="@+id/editText2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="24dp"
    android:layout_marginTop="24dp"
    android:padding="12dp"
    android:gravity="center"
    android:inputType="text"
    android:text="Default background." />
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)

  • Sparky是正确的,虽然您可以复制iOS控件的外观和感觉,但强烈建议您使用与Android平台外观相匹配的控件.这为Android平台上的其他应用提供了更加一致的用户体验. (3认同)