如下图:
要实现上面的功能,需要做到三点:
1、实现矩形框布局
思路就是矩形框作为整个布局的一个background,在drawable中创建一个shap.xml样式文件
class="brush:java;gutter:true;"><?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle" > <padding android:bottom="1dp" android:left="1dp" android:right="1dp" android:top="1dp" /> <!-- 设置圆角矩形 --> <!--<corners android:radius="3dp" />--> <stroke android:width="1px" android:color="#000" /> <solid android:color="#ffff" /> </shape>
在布局文件中设置 android:background="@drawable/shap"
然后将editText和Textview按照要求布局到该矩形区域中
2、隐藏editText的下划线
默认情况下,editText中输入文字后,下面都会有下划线,可以使用 android:background="@null"
将其下划线隐藏。
3、计算剩余字数
这个问题可以通过对editText控件调用addTextChangedListener()方法实现监听
final int maxNum = 500; final TextView leftNum = (TextView) findViewById(R.id.leftNum); EditText ed = (EditText) findViewById(R.id.nikeName); ed.addTextChangedListener(new TextWatcher() { @Override public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override public void onTextChanged(CharSequence s, int start, int before, int count) { } @Override public void afterTextChanged(Editable s) { leftNum.setText("剩余字数:"+ (maxNum-s.length())); } });