`

2010.12.23——— ListView的分割线 以及给其他View加分割线

阅读更多
2010.12.23——— ListView的分割线 以及给其他View加分割线

参考:http://androidstudy.iteye.com/blog/771076
http://androidstudy.iteye.com/blog/770512

1、ListView


listView的分割线 是可以自己定义的 也是可以控制的

<LinearLayout 
  xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content"> 
 
     <ListView  
        android:id="@+id/android:list" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:divider="#FFCC00" 
        android:dividerHeight="4px"/> 
 
</LinearLayout> 


在Android平台中系统控件提供了灵活的自定义选项,所有基于ListView或者说AbsListView实现的widget控件均可以通过下面的方法设置行间距的分割线,分割线可以自定义颜色、或图片。
     在ListView中我们使用属性   android:divider="#FF0000" 定义分隔符为红色,当然这里值可以指向一个drawable图片对象,如果使用了图片可能高度大于系统默认的像素,可以自己设置高度比如6个像素   android:dividerHeight="6px" ,Android开发网提示当然在Java中ListView也有相关方法可以设置。


2、其他View

两种方法

我用的是第一种 因为简单 呵呵

A:用TextView来表示分割线


  
<TextView
	  	android:layout_width="fill_parent"
	 	android:layout_height="1px"
	 	android:paddingTop="2px"
	 	android:paddingBottom="2px"
	 	android:background="#666666"
	 	 />




B:自定义View

首先:自定义EditText

//请在这里添加您的包名
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.widget.EditText;

public class LineEditText extends EditText {

	private Paint mPaint;
	/**
	 * @param context
	 * @param attrs
	 */
	public LineEditText(Context context, AttributeSet attrs) {
		super(context, attrs);
		// TODO Auto-generated constructor stub
		mPaint = new Paint();
		
		mPaint.setStyle(Paint.Style.STROKE);
		mPaint.setColor(Color.BLUE);
	}
	
	@Override
	public void onDraw(Canvas canvas)
	{
		super.onDraw(canvas);
		
//		画底线
		canvas.drawLine(0,this.getHeight()-1,  this.getWidth()-1, this.getHeight()-1, mPaint);
	}
}


其次:设置LineEditText

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:layout_width="fill_parent"
	android:layout_height="fill_parent"
	>
<!--注意名称 -->
<com.marine.study.LineEditText 
	
    android:id="@+id/myEdit"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    style="?android:attr/textViewStyle" 
    android:background="@null"
    android:textColor="@null" 
/>
</LinearLayout>


最后:应用LineEditText


import android.app.Activity;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.os.Bundle;
import android.text.InputFilter;
import android.util.AttributeSet;
import android.widget.EditText;

public class LineEditTextTest extends Activity {
    /** Called when the activity is first created. */
	private EditText mEdit;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        mEdit=(LineEditText)findViewById(R.id.myEdit);
        mEdit.setHint("从这里开始输入...");
        mEdit.setSingleLine();
        mEdit.setFilters(new InputFilter[]{new InputFilter.LengthFilter(20)});
    }
    
}







分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics