4

Androidには、TextViewがあり、そのコンテンツは動的になります。テキストの各行の後に水平線を表示したいと思います。私はたくさん検索して、EditTextを見つけました(AndroidのEditTextでテキストを整列させるために罫線/水平線を使用する方法は?)。ダイナミックなTextViewとその下に水平線を描くことを計画していました。しかし、どうすれば行末を検出できるのかわかりません。どんな助けでも大歓迎です。AndroidのEditTextでテキストを整列させるために罫線/水平線を使用する方法の添付画像と同じ効果が欲しいですか?

4

3 に答える 3

8

EditTextのテキストの各行の間に線を引く手法を使用しています。次に、カスタム EditText オブジェクトにsetKeyListener(null)を設定してEditTextを編集不可にし、EditText がTextViewのように機能するようにします:)


表示されるテキストの各行の間に線を引くカスタム EditText:

public class LinedEditText extends EditText {
    private Rect mRect;
    private Paint mPaint;

    // we need this constructor for LayoutInflater
    public LinedEditText(Context context, AttributeSet attrs) {
        super(context, attrs);

        mRect = new Rect();
        mPaint = new Paint();
        mPaint.setStyle(Paint.Style.STROKE);
        mPaint.setColor(0x800000FF);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        int count = getLineCount();
        Rect r = mRect;
        Paint paint = mPaint;

        for (int i = 0; i < count; i++) {
            int baseline = getLineBounds(i, r);

            canvas.drawLine(r.left, baseline + 1, r.right, baseline + 1, paint);
        }

        super.onDraw(canvas);
    }
} 

TextViewが必要なLinedEditTextクラスのオブジェクトを使用して、編集不可にします。

例:

public class HorizontalLine extends Activity{
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {   
        super.onCreate(savedInstanceState);
        setTitle("Android: Ruled/horizonal lines in Textview");

        LinearLayout ll = new LinearLayout(this);
        ll.setOrientation(LinearLayout.VERTICAL);
        LayoutParams textViewLayoutParams = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);

        LinedEditText et = new LinedEditText(this, null);
        et.setText("The name of our country is Bangladesh. I am proud of my country :)");
        et.setLayoutParams(textViewLayoutParams);
        et.setKeyListener(null);

        ll.addView(et);
        this.setContentView(ll);

    }

}

et.setKeyListener(null)は EditText を編集不可にするため、TextView のように機能します。


出力:

ここに画像の説明を入力

カーソルの問題:

et.setKeyListener(null)のみを使用すると、キーをリッスンしませんが、ユーザーは EditText にカーソルを表示できます。このカーソルが必要ない場合は、次の行を追加して EditText を無効にします。

 et.setEnabled(false);
于 2012-05-26T23:40:43.783 に答える
1

線を描画するためにビューを使用できます: 水平線の場合:

<View
android:layout_height="1dp"
android:layout_width="fill_parent"
android:background="#ffffff" />
于 2012-05-25T04:51:12.357 に答える
0
<TextView  
android:layout_height="1dp"  
android:layout_width="fill_parent"/>
于 2012-05-25T04:39:35.563 に答える