我在画布上创建了一个圆形剪辑路径,我在画布上有一列数字动画,因此我在剪切的部分看到数字动画并动画显示。 这是裁剪代码:
mClipPath.addCircle((w / 2f), (h / 2f), radius, Path.Direction.CW);
canvas.clipPath(mClipPath, Region.Op.INTERSECT);
但在某些情况下,剪辑在动画期间不会正常发生(左边是3和4)。
这只发生在牛轧糖上。
答案 0 :(得分:1)
我看到了同样的问题。在下面滚动包含CircleCropDrawable的RecyclerView时,我可以看到剪裁和不剪裁之间的可绘制闪光,具体取决于滚动位置。
然而,通过反复试验,我看到这只发生在路径与drawable的边缘相交时。将半径减小1dp可以解决问题(小于1dp不起作用)
<强> CircleCropDrawable.java 强>
package com.someone.android.view;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.ColorFilter;
import android.graphics.Path;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.support.annotation.NonNull;
import android.util.TypedValue;
public class CircleCropDrawable extends Drawable {
private final Context mContext;
private final Drawable mDrawable;
public CircleCropDrawable(Context context, Drawable drawable) {
mContext = context;
this.mDrawable = drawable;
}
@Override
public void draw(@NonNull Canvas canvas) {
final float width = getBounds().width();
final float height = getBounds().height();
final Path path = new Path();
// There seems to be a bug in N where the clip path doesn't work when animating
// without a 1dp reduction in radius, the drawable unclips when scrolling in a RecyclerView
float inset = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 2, mContext.getResources().getDisplayMetrics());
path.addCircle(width / 2, height / 2, Math.min(width / 2, height / 2) - inset, Path.Direction.CW);
canvas.clipPath(path);
mDrawable.draw(canvas);
}
@Override
protected void onBoundsChange(Rect bounds) {
mDrawable.setBounds(bounds);
}
@Override
public int getIntrinsicWidth() {
return mDrawable.getIntrinsicWidth();
}
@Override
public int getIntrinsicHeight() {
return mDrawable.getIntrinsicHeight();
}
@Override
public void setAlpha(int i) {
mDrawable.setAlpha(i);
}
@Override
public void setColorFilter(ColorFilter colorFilter) {
mDrawable.setColorFilter(colorFilter);
}
@Override
public int getOpacity() {
return mDrawable.getOpacity();
}
}
答案 1 :(得分:1)
我已经向Google提交了一个错误,似乎已经解决了。以下是该错误的链接:
答案 2 :(得分:0)
我们通过禁用硬件加速来修复此问题,如下所示:
myView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);