本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
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持呐喊教程!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。