本Demo是一款仿qq未读消息拖拽删除的例子,继承RelativeLayout的WaterDrop实现了圆形图标功能、继承ImageView的CircleImageView圆形图片功能、效果非常不错、很适合有圆形设计的哥们、效果图片如下
CircleImageView核心代码
private void updateShaderMatrix() { float scale; float dx = 0; float dy = 0; mShaderMatrix.set(null); if (mBitmapWidth * mDrawableRect.height() > mDrawableRect.width() * mBitmapHeight) { scale = mDrawableRect.height() / (float) mBitmapHeight; dx = (mDrawableRect.width() - mBitmapWidth * scale) * 0.5f; } else { scale = mDrawableRect.width() / (float) mBitmapWidth; dy = (mDrawableRect.height() - mBitmapHeight * scale) * 0.5f; } mShaderMatrix.setScale(scale, scale); mShaderMatrix.postTranslate((int) (dx 0.5f) mBorderWidth, (int) (dy 0.5f) mBorderWidth); mBitmapShader.setLocalMatrix(mShaderMatrix);}
WaterDrop核心代码
public boolean onTouchEvent(MotionEvent event) { ViewGroup parent = getScrollableParent(); switch (event.getAction()) { case MotionEvent.ACTION_DOWN: mHolderEventFlag = !CoverManager.getInstance().isRunning(); if (mHolderEventFlag) { parent.requestDisallowInterceptTouchEvent(true); CoverManager.getInstance().start(this, event.getRawX(), event.getRawY(), mOnDragCompeteListener); } break; case MotionEvent.ACTION_MOVE: if (mHolderEventFlag) { CoverManager.getInstance().update(event.getRawX(), event.getRawY()); } break; case MotionEvent.ACTION_UP: case MotionEvent.ACTION_CANCEL: if (mHolderEventFlag) { parent.requestDisallowInterceptTouchEvent(false); CoverManager.getInstance().finish(this, event.getRawX(), event.getRawY()); } break; } return true;}
最后给贴上Demo的源代码,有兴趣的朋友可以下载看看
http://pan.baidu.com/s/1kU8OGL5
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持武林网!
新闻热点
疑难解答