/*
* Copyright (C) 2008 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.
*/
package android.renderscript;
/**
* @hide
* @deprecated in API 16
* Program raster is primarily used to specify whether point sprites are enabled and to control
* the culling mode. By default, back faces are culled.
**/
public class ProgramRaster extends BaseObj {
/**
* @deprecated in API 16
**/
public enum CullMode {
/**
* @deprecated in API 16
**/
BACK (0),
/**
* @deprecated in API 16
**/
FRONT (1),
/**
* @deprecated in API 16
**/
NONE (2);
int mID;
CullMode(int id) {
mID = id;
}
}
boolean mPointSprite;
CullMode mCullMode;
ProgramRaster(long id, RenderScript rs) {
super(id, rs);
mPointSprite = false;
mCullMode = CullMode.BACK;
}
/**
* @deprecated in API 16
* Specifies whether vertices are rendered as screen aligned
* elements of a specified size
* @return whether point sprites are enabled
*/
public boolean isPointSpriteEnabled() {
return mPointSprite;
}
/**
* @deprecated in API 16
* Specifies how triangles are culled based on their orientation
* @return cull mode
*/
public CullMode getCullMode() {
return mCullMode;
}
/**
* @deprecated in API 16
*/
public static ProgramRaster CULL_BACK(RenderScript rs) {
if(rs.mProgramRaster_CULL_BACK == null) {
ProgramRaster.Builder builder = new ProgramRaster.Builder(rs);
builder.setCullMode(CullMode.BACK);
rs.mProgramRaster_CULL_BACK = builder.create();
}
return rs.mProgramRaster_CULL_BACK;
}
/**
* @deprecated in API 16
*/
public static ProgramRaster CULL_FRONT(RenderScript rs) {
if(rs.mProgramRaster_CULL_FRONT == null) {
ProgramRaster.Builder builder = new ProgramRaster.Builder(rs);
builder.setCullMode(CullMode.FRONT);
rs.mProgramRaster_CULL_FRONT = builder.create();
}
return rs.mProgramRaster_CULL_FRONT;
}
/**
* @deprecated in API 16
*/
public static ProgramRaster CULL_NONE(RenderScript rs) {
if(rs.mProgramRaster_CULL_NONE == null) {
ProgramRaster.Builder builder = new ProgramRaster.Builder(rs);
builder.setCullMode(CullMode.NONE);
rs.mProgramRaster_CULL_NONE = builder.create();
}
return rs.mProgramRaster_CULL_NONE;
}
/**
* @deprecated in API 16
*/
public static class Builder {
RenderScript mRS;
boolean mPointSprite;
CullMode mCullMode;
/**
* @deprecated in API 16
*/
public Builder(RenderScript rs) {
mRS = rs;
mPointSprite = false;
mCullMode = CullMode.BACK;
}
/**
* @deprecated in API 16
*/
public Builder setPointSpriteEnabled(boolean enable) {
mPointSprite = enable;
return this;
}
/**
* @deprecated in API 16
*/
public Builder setCullMode(CullMode m) {
mCullMode = m;
return this;
}
/**
* @deprecated in API 16
*/
public ProgramRaster create() {
mRS.validate();
long id = mRS.nProgramRasterCreate(mPointSprite, mCullMode.mID);
ProgramRaster programRaster = new ProgramRaster(id, mRS);
programRaster.mPointSprite = mPointSprite;
programRaster.mCullMode = mCullMode;
return programRaster;
}
}
}