2012-08-31 20:31:01 -07:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2012 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ANDROID_HWUI_STENCIL_H
|
|
|
|
#define ANDROID_HWUI_STENCIL_H
|
|
|
|
|
|
|
|
#ifndef LOG_TAG
|
|
|
|
#define LOG_TAG "OpenGLRenderer"
|
|
|
|
#endif
|
|
|
|
|
2013-02-06 16:51:04 -08:00
|
|
|
#include <GLES2/gl2.h>
|
|
|
|
|
2012-08-31 20:31:01 -07:00
|
|
|
#include <cutils/compiler.h>
|
|
|
|
|
|
|
|
namespace android {
|
|
|
|
namespace uirenderer {
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Stencil buffer management
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
class ANDROID_API Stencil {
|
|
|
|
public:
|
|
|
|
Stencil();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the desired size for the stencil buffer. If the returned value
|
|
|
|
* is 0, then no stencil buffer is required.
|
|
|
|
*/
|
|
|
|
ANDROID_API static uint32_t getStencilSize();
|
|
|
|
|
2013-02-06 16:51:04 -08:00
|
|
|
/**
|
|
|
|
* Returns the smallest stencil format accepted by render buffers.
|
|
|
|
*/
|
|
|
|
static GLenum getSmallestStencilFormat();
|
|
|
|
|
2012-08-31 20:31:01 -07:00
|
|
|
/**
|
|
|
|
* Clears the stencil buffer.
|
|
|
|
*/
|
|
|
|
void clear();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enables stencil test. When the stencil test is enabled the stencil
|
|
|
|
* buffer is not written into.
|
|
|
|
*/
|
|
|
|
void enableTest();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enables stencil write. When stencil write is enabled, the stencil
|
|
|
|
* test always succeeds and the value 0x1 is written in the stencil
|
|
|
|
* buffer for each fragment.
|
|
|
|
*/
|
|
|
|
void enableWrite();
|
|
|
|
|
2012-09-21 19:15:00 -07:00
|
|
|
/**
|
|
|
|
* The test passes only when equal to the specified value.
|
|
|
|
*/
|
|
|
|
void enableDebugTest(GLint value, bool greater = false);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used for debugging. The stencil test always passes and increments.
|
|
|
|
*/
|
|
|
|
void enableDebugWrite();
|
|
|
|
|
2012-08-31 20:31:01 -07:00
|
|
|
/**
|
|
|
|
* Disables stencil test and write.
|
|
|
|
*/
|
|
|
|
void disable();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Indicates whether either test or write is enabled.
|
|
|
|
*/
|
|
|
|
bool isEnabled() {
|
|
|
|
return mState != kDisabled;
|
|
|
|
}
|
|
|
|
|
2013-02-25 14:15:37 -08:00
|
|
|
/**
|
|
|
|
* Indicates whether testing only is enabled.
|
|
|
|
*/
|
|
|
|
bool isTestEnabled() {
|
|
|
|
return mState == kTest;
|
|
|
|
}
|
|
|
|
|
2012-08-31 20:31:01 -07:00
|
|
|
private:
|
|
|
|
void enable();
|
|
|
|
|
|
|
|
enum StencilState {
|
|
|
|
kDisabled,
|
|
|
|
kTest,
|
|
|
|
kWrite
|
|
|
|
};
|
|
|
|
|
|
|
|
StencilState mState;
|
|
|
|
|
|
|
|
}; // class Stencil
|
|
|
|
|
|
|
|
}; // namespace uirenderer
|
|
|
|
}; // namespace android
|
|
|
|
|
|
|
|
#endif // ANDROID_HWUI_STENCIL_H
|