Android绘图:Canvas绘制联系人姓氏侧滑列表

从A到Z字母的滑动

public class MySlide extends View{
    private int mWidth;
    private int mHeight;
    private Paint mPaintText;
    private Paint mPaintRed;
    private int index=-1;
    private String [] array={"a","b","c","d","e","f","g","h","i","j",
            "k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z"};
    public interface OnItemSelect{
        public void OnItemSelected(int index,String indexString);

    }
     private OnItemSelect listener;

    public void setOnItemSelectListener(OnItemSelect listener) {
        this.listener = listener;
    }

    public MySlide(Context context) {
        super(context);
    }

    public MySlide(Context context, AttributeSet attrs) {
        super(context, attrs);
        mPaintText=new Paint();
        mPaintText.setTextAlign(Paint.Align.CENTER);
        mPaintRed=new Paint();
        mPaintRed.setColor(Color.RED);
        mPaintRed.setTextAlign(Paint.Align.CENTER);
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        mWidth = getDefaultSize(getSuggestedMinimumWidth(), widthMeasureSpec);
        mHeight = getDefaultSize(getSuggestedMinimumHeight(), heightMeasureSpec);
        setMeasuredDimension(getDefaultSize(getSuggestedMinimumWidth(), widthMeasureSpec),
                getDefaultSize(getSuggestedMinimumHeight(), heightMeasureSpec));
        //这个不能放在构造器里面,因为在这之前还没有得到宽和高,值是默认的0,所以要放在onMeasure里。
        mPaintText.setTextSize(mHeight/26f);
        mPaintRed.setTextSize(mHeight/26f);
    }
private float y;
    private float x;
    @Override
    public boolean onTouchEvent(MotionEvent event) {

        switch (event.getAction()){
            case MotionEvent.ACTION_DOWN:
            case MotionEvent.ACTION_MOVE:
                x=event.getX();
                y=event.getY();
                if (x>mWidth-mPaintText.measureText("m")*2){
                    index=(int)y/(mHeight/26);//用商确定点到哪一个字母了
                    Log.d("onTouch", "点击到按钮是:" + array[index]);
                   if (listener!=null){
                       //因为Listener在上面已经声明了接口和定义了方法,所以可以直接使用
                       listener.OnItemSelected(index,array[index]);
                   }
                    invalidate();//改变值后,立即刷新
                    return true;
                }
                break;
            case MotionEvent.ACTION_UP:
                index=-1;
                invalidate();
                return true;
                default:
                    break;
        }
        return super.onTouchEvent(event);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        for (int i=0;i<array.length;i++){
            if (index==i){
                canvas.drawText(""+array[i],mWidth-mPaintText.measureText("m"),mHeight/26f*(i+1),mPaintRed);
            }else {
                //根据屏幕大小来选择摆放位置
                canvas.drawText(""+array[i],mWidth-mPaintText.measureText("m"),mHeight/26f*(i+1),mPaintText);
            }

        }
    }
}

主函数

public class MainActivity extends AppCompatActivity {
  private TextView mTextView;
    private MySlide myslide;
     @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
         mTextView= (TextView) findViewById(R.id.textview);
        myslide= (MySlide) findViewById(R.id.myslide);
        myslide.setOnItemSelectListener(new MySlide.OnItemSelect() {
            @Override
            public void OnItemSelected(int index,String indexString) {
          mTextView.setText(indexString);
            }
        });

    }

}

布局

<com.example.administrator.definedviewdemo.Wiget.MySlide
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/myslide"/>
    <TextView
        android:id="@+id/textview"
        android:text="A"
        android:gravity="center"
        android:textSize="100sp"
        android:layout_width="200dp"
        android:layout_height="200dp"
        />

图片

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值