本Demo是一款仿qq未讀消息拖拽刪除的例子,繼承RelativeLayout的WaterDrop實(shí)現(xiàn)了圓形圖標(biāo)功能、繼承ImageView的CircleImageView圓形圖片功能、效果非常不錯(cuò)、很適合有圓形設(shè)計(jì)的哥們、效果圖片如下

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
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持武林網(wǎng)!
新聞熱點(diǎn)
疑難解答
圖片精選