8b4548c43a
This CL marks RenderScript Java APIs as deprecated. Bug: 168711199 Test: m Test: CtsRenderscriptTestCases Test: CtsRsCppTestCases Test: CtsRsBlasTestCases Change-Id: Id271a794679d445c480d62c87ae6c8150f6901f8
175 lines
4.4 KiB
Java
175 lines
4.4 KiB
Java
/*
|
|
* 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;
|
|
|
|
import android.compat.annotation.UnsupportedAppUsage;
|
|
|
|
|
|
/**
|
|
* @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.
|
|
**/
|
|
@Deprecated
|
|
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
|
|
*/
|
|
@UnsupportedAppUsage
|
|
public Builder(RenderScript rs) {
|
|
mRS = rs;
|
|
mPointSprite = false;
|
|
mCullMode = CullMode.BACK;
|
|
}
|
|
|
|
/**
|
|
* @deprecated in API 16
|
|
*/
|
|
@UnsupportedAppUsage
|
|
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
|
|
*/
|
|
@UnsupportedAppUsage
|
|
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;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|