Merge "Revert "Add a way to override Xfermode DO NOT MERGE"" into lmp-mr1-dev

This commit is contained in:
Chris Craik
2014-11-21 22:11:11 +00:00
committed by Android (Google) Code Review
5 changed files with 12 additions and 62 deletions

View File

@ -997,15 +997,4 @@ class GLES20Canvas extends HardwareCanvas {
int indexOffset, int indexCount, Paint paint) { int indexOffset, int indexCount, Paint paint) {
// TODO: Implement // TODO: Implement
} }
@Override
public void setOverrideXfermode(PorterDuff.Mode xfermode) {
int xfermodeValue = -1;
if (xfermode != null) {
xfermodeValue = xfermode.nativeInt;
}
nSetOverrideXfermode(mRenderer, xfermodeValue);
}
private static native void nSetOverrideXfermode(long renderer, int xfermode);
} }

View File

@ -172,12 +172,6 @@ static jint android_view_GLES20Canvas_getMaxTextureHeight(JNIEnv* env, jobject c
return Caches::getInstance().maxTextureSize; return Caches::getInstance().maxTextureSize;
} }
static void android_view_GLES20Canvas_setOverrideXfermode(JNIEnv* env, jobject clazz,
jlong rendererPtr, int xfermode) {
DisplayListRenderer* renderer = reinterpret_cast<DisplayListRenderer*>(rendererPtr);
renderer->setOverrideXfermode(xfermode);
}
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// State // State
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@ -970,8 +964,6 @@ static JNINativeMethod gMethods[] = {
{ "nGetMaximumTextureWidth", "()I", (void*) android_view_GLES20Canvas_getMaxTextureWidth }, { "nGetMaximumTextureWidth", "()I", (void*) android_view_GLES20Canvas_getMaxTextureWidth },
{ "nGetMaximumTextureHeight", "()I", (void*) android_view_GLES20Canvas_getMaxTextureHeight }, { "nGetMaximumTextureHeight", "()I", (void*) android_view_GLES20Canvas_getMaxTextureHeight },
{ "nSetOverrideXfermode", "(JI)V", (void*) android_view_GLES20Canvas_setOverrideXfermode },
#endif #endif
}; };

View File

@ -249,15 +249,6 @@ public class Canvas {
/** @hide */ /** @hide */
public void insertInorderBarrier() {} public void insertInorderBarrier() {}
/**
* Set a transfer mode that overrides any transfer modes
* in paints used for drawing. Pass null to disable this
* override. Only implemented in GLES20Canvas.
*
* @hide
*/
public void setOverrideXfermode(@Nullable PorterDuff.Mode xfermode) {}
/** /**
* Return true if the device that the current layer draws into is opaque * Return true if the device that the current layer draws into is opaque
* (i.e. does not support per-pixel alpha). * (i.e. does not support per-pixel alpha).

View File

@ -39,7 +39,6 @@ DisplayListRenderer::DisplayListRenderer()
, mTranslateY(0.0f) , mTranslateY(0.0f)
, mDeferredBarrierType(kBarrier_None) , mDeferredBarrierType(kBarrier_None)
, mHighContrastText(false) , mHighContrastText(false)
, mOverrideXfermode(-1)
, mRestoreSaveCount(-1) { , mRestoreSaveCount(-1) {
} }

View File

@ -20,7 +20,6 @@
#include <SkMatrix.h> #include <SkMatrix.h>
#include <SkPaint.h> #include <SkPaint.h>
#include <SkPath.h> #include <SkPath.h>
#include <SkPorterDuff.h>
#include <cutils/compiler.h> #include <cutils/compiler.h>
#include "DisplayListLogBuffer.h" #include "DisplayListLogBuffer.h"
@ -162,15 +161,6 @@ public:
void setHighContrastText(bool highContrastText) { void setHighContrastText(bool highContrastText) {
mHighContrastText = highContrastText; mHighContrastText = highContrastText;
} }
void setOverrideXfermode(int xfermode) {
if (xfermode != -1) {
SkPorterDuff::Mode porterDuffMode = static_cast<SkPorterDuff::Mode>(xfermode);
xfermode = SkPorterDuff::ToXfermodeMode(porterDuffMode);
}
mOverrideXfermode = xfermode;
};
private: private:
enum DeferredBarrierType { enum DeferredBarrierType {
kBarrier_None, kBarrier_None,
@ -230,26 +220,18 @@ private:
inline const SkPaint* refPaint(const SkPaint* paint) { inline const SkPaint* refPaint(const SkPaint* paint) {
if (!paint) return NULL; if (!paint) return NULL;
const SkPaint* paintCopy; const SkPaint* paintCopy = mPaintMap.valueFor(paint);
if (paintCopy == NULL
if (mOverrideXfermode != -1) { || paintCopy->getGenerationID() != paint->getGenerationID()
SkPaint* overriddenPaint = copyPaint(paint); // We can't compare shader pointers because that will always
overriddenPaint->setXfermodeMode(static_cast<SkXfermode::Mode>(mOverrideXfermode)); // change as we do partial copying via wrapping. However, if the
paintCopy = overriddenPaint; // shader changes the paint generationID will have changed and
} else { // so we don't hit this comparison anyway
paintCopy = mPaintMap.valueFor(paint); || !(paint->getShader() && paintCopy->getShader()
if (paintCopy == NULL && paint->getShader()->getGenerationID() == paintCopy->getShader()->getGenerationID())) {
|| paintCopy->getGenerationID() != paint->getGenerationID() paintCopy = copyPaint(paint);
// We can't compare shader pointers because that will always // replaceValueFor() performs an add if the entry doesn't exist
// change as we do partial copying via wrapping. However, if the mPaintMap.replaceValueFor(paint, paintCopy);
// shader changes the paint generationID will have changed and
// so we don't hit this comparison anyway
|| !(paint->getShader() && paintCopy->getShader()
&& paint->getShader()->getGenerationID() == paintCopy->getShader()->getGenerationID())) {
paintCopy = copyPaint(paint);
// replaceValueFor() performs an add if the entry doesn't exist
mPaintMap.replaceValueFor(paint, paintCopy);
}
} }
return paintCopy; return paintCopy;
@ -322,9 +304,6 @@ private:
DeferredBarrierType mDeferredBarrierType; DeferredBarrierType mDeferredBarrierType;
bool mHighContrastText; bool mHighContrastText;
// -1 if unset, or SkXfermode::Mode value if set
int mOverrideXfermode;
int mRestoreSaveCount; int mRestoreSaveCount;
friend class RenderNode; friend class RenderNode;