大佬教程收集整理的这篇文章主要介绍了Android侧边栏滑动切换的view效果,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
import android.content.Context; import android.graphics.Canvas; import android.graphics.Paint; import android.graphics.drawable.bitmapDrawable; import android.util.AttributeSet; import android.view.MotionEvent; import android.view.View; public class SideBar extends View { private static final int MARGIN_BOTTOM = 2; privatE int mItemHeight = 18; private OnLetterTouchListener mOnLetterTouchListener; private Paint mPaint; private float mWidthCenter; privatE int BACkgroundColor = 0x00F0F0F0; private char[] chars = AppCommon.INDEXER_CHARS; public interface OnLetterTouchListener { public abstract void onPressedDown(int index,char ch); public abstract void onPressedUp(int index,char ch); } public SideBar(Context context) { this(context,null); } public SideBar(Context context,AttributeSet attrs) { this(context,attrs,-1); } public SideBar(Context context,AttributeSet attrs,int defStylE) { super(context,defStylE); init(); } privatE int startY = 0;//其实位置的y轴坐标 public SideBar setChars(char[] chars) { this.chars = chars; // for(int i = 0 ; i < (26 - chars.length) / 2 ; i++){ // startY += i * mItemHeight; // } init(); posTinvalidate(); return this; } private void init() { mPaint = new Paint(); mPaint.setColor(0xFFCFCFD0); mPaint.setAntiAlias(true); mPaint.setFakeBoldText(true); mPaint.setTextSize(32); mPaint.setColor(getresources().getColor(R.color.bluE)); mPaint.setSubpixelText(true); mPaint.setTextAlign(Paint.Align.CENTER); setBACkgroundColor(BACkgroundColor); } public Boolean onTouchEvent(MotionEvent event) { super.onTouchEvent(event); int idx = (int) event.getY() / mItemHeight; if (idx >= chars.length) { idx = chars.length - 1; } else if (idx < 0) { idx = 0; } if (event.getAction() == MotionEvent.ACTION_DOWN || event.getAction() == MotionEvent.ACTION_MOVE) { setBACkgroundresource(R.color.sidebar_SELEcT_Background); if (mOnLetterTouchListener != null) { mOnLetterTouchlistener.onPressedDown(idx,chars[idx]); } } else if (event.getAction() == MotionEvent.ACTION_Up) { setBACkgroundDrawable(new BitmapDrawable()); setBACkgroundColor(BACkgroundColor); if (mOnLetterTouchListener != null) { mOnLetterTouchlistener.onPressedUp(idx,chars[idx]); } } return true; } @Override protected void onSizeChanged(int w,int h,int oldw,int oldh) { mItemHeight = (h - MARGIN_BOTTOM) / 26; mWidthCenter = getMeasuredWidth() / 2; super.onSizeChanged(w,h,oldw,oldh); } protected void onDraw(Canvas canvas) { for (int i = 0; i < chars.length; i++) { canvas.drawText(@R_696_10495@ng.valueOf(chars[i]),mWidthCenter,startY + mItemHeight + (i * mItemHeight),mPaint); } super.onDraw(canvas); } public void setOnLetterTouchListener(OnLetterTouchListener listener) { mOnLetterTouchListener = listener; } }
以上所述是小编给大家介绍的Android侧边栏滑动切换的view效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!
以上是大佬教程为你收集整理的Android侧边栏滑动切换的view效果全部内容,希望文章能够帮你解决Android侧边栏滑动切换的view效果所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。