我的问题是,如何在 android的editBox中放置标签?
例如,我想将“收件人:”放在联系人选择器的编辑框中,即使我按屏幕键盘上的退格键也不会被删除。
我尝试使用android:hint,但是当 editBox 成为焦点或单击时它会被删除。
我尝试了图像,但看起来不太好。所以,我需要一种方法来实现这个标签。
见视觉图
我的问题是,如何在 android的editBox中放置标签?
例如,我想将“收件人:”放在联系人选择器的编辑框中,即使我按屏幕键盘上的退格键也不会被删除。
我尝试使用android:hint,但是当 editBox 成为焦点或单击时它会被删除。
我尝试了图像,但看起来不太好。所以,我需要一种方法来实现这个标签。
见视觉图
我给你两个想法来做到这一点:
如果您只在几个地方需要它,您可以使用 FrameLayout / merge 在您的 EditText 上放置一个 TextView。然后在编辑文本上使用填充,您可以使 TextView 看起来像是在 EditText“内部”。:
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<EditText
android:id="@+id/editText1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingLeft="40dp" >
<requestFocus />
</EditText>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:paddingLeft="10dp"
android:text="To : " />
</FrameLayout>
否则,您可以通过编写自己的类来实现自己的 EditText 版本。这是一个基本示例,您需要对其进行一些调整:
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Rect;
import android.text.TextPaint;
import android.util.AttributeSet;
import android.widget.EditText;
public class LabelledEditText extends EditText {
public LabelledEditText(Context context) {
super(context);
mPaddingLeft = getPaddingLeft();
}
public LabelledEditText(Context context, AttributeSet attrs) {
super(context, attrs);
mPaddingLeft = getPaddingLeft();
}
protected void onDraw(Canvas canvas) {
TextPaint textPaint = getPaint();
Rect size = new Rect();
textPaint.getTextBounds(mLabel, 0, mLabel.length(), size);
setPadding(mPaddingLeft + size.width(), getPaddingTop(), getPaddingRight(), getPaddingBottom());
super.onDraw(canvas);
canvas.drawText(mLabel, mPaddingLeft + size.left, size.bottom + getPaddingTop(), textPaint);
}
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
}
private String mLabel = "To : ";
private int mPaddingLeft;
}
您总是可以在 a中添加一个TextView
+ ,如下所示:EditText
LinearLayout
EditText
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@android:drawable/edit_text" >
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:text="To:" />
<EditText
android:id="@+id/editText1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:layout_marginLeft="3dp"
android:background="@null" />
</LinearLayout>
试试这个
<LinearLayout
android:id="@+id/linearLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="5dp" >
<RelativeLayout
android:id="@+id/linearlayout2"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:text="To:" />
<EditText
android:id="@+id/editTextTo"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="20dp"
android:background="@android:color/transparent"
android:hint="Type your text..."
android:singleLine="true"
android:textColor="#000000" />
</RelativeLayout>
</LinearLayout>
在android中,标签被称为TextView
:
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="To:"
/>
<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content"
/>
</LinearLayout>
EditText
没有标签,所以你需要两者。值得庆幸ViewGroup
的是,这对开发人员来说相对轻松。因此,EditText
usesfill_parent
属性与“To:”标签紧密相关。
然后用这个...
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<EditText
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TO:"
/>
</LinearLayout>
你可以像这样添加
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.home_screen);
EditText edittext = (EditText)getViewById(R.id.edittextid);
edittext.setText("To:")
}
然后,您将在开始活动时看到文本。
我希望它有帮助....
您可以使用 Here FrameLayout,您可以在其中使用 3 个小部件:
1.TextView 设置文本“TO”
在 TextView 旁边你可以有 Edittext 在那里你可以输入数据
最后是显示十字符号的 ImageButton...
用圆角矩形设置 FrameLayout 的背景图像,,,,
圆形文本视图
<LinearLayout
android:id="@+id/linearLayoutSearch"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@android:color/transparent"
android:padding="5dp" >
<RelativeLayout
android:id="@+id/linearlayout2"
android:layout_width="fill_parent"
android:layout_height="36dp"
android:layout_marginLeft="5dp"
android:layout_marginRight="5dp"
android:background="@drawable/rounded_textview"
android:paddingLeft="5dp" >
<TextView
android:layout_width="22dp"
android:layout_height="22dp"
android:layout_centerVertical="true"
android:alignParentLeft="true"
android:text="To:" />
<EditText
android:id="@+id/search"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="25dp"
android:layout_marginRight="25dp"
android:background="@android:color/transparent"
android:hint="Enter your text..."
android:imeOptions="actionDone"
android:singleLine="true"
android:textColor="#000000" />
<ImageView
android:layout_width="22dp"
android:layout_height="22dp"
android:layout_centerVertical="true"
android:alignParentRight="true"
android:src="@drawable/stop" />
</RelativeLayout>
</LinearLayout>
rounded_textview.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:padding="10dp"
android:shape="rectangle" >
<solid android:color="#FFFFFF" />
<corners
android:bottomLeftRadius="15dp"
android:bottomRightRadius="15dp"
android:topLeftRadius="15dp"
android:topRightRadius="15dp" />
</shape>
<EditText
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TO:"
/>