blob: 33000acb4eb084d797570f1b752cec5a43ebe5ab [file] [log] [blame]
Jason Samsebfb4362009-09-23 13:57:02 -07001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package android.renderscript;
18
Mathew Inwoodf0c90b12018-08-01 10:05:11 +010019import android.annotation.UnsupportedAppUsage;
20
Jason Samsebfb4362009-09-23 13:57:02 -070021
Stephen Hines9c9ad3f8c22012-05-07 15:34:29 -070022/**
Tim Murraya9084222013-04-05 22:06:43 +000023 * @hide
Jason Samsd4ca9912012-05-08 19:02:07 -070024 * @deprecated in API 16
Robert Ly11518ac2011-02-09 13:57:06 -080025 * Program raster is primarily used to specify whether point sprites are enabled and to control
26 * the culling mode. By default, back faces are culled.
Jason Samsebfb4362009-09-23 13:57:02 -070027 **/
28public class ProgramRaster extends BaseObj {
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -070029
Jason Samsd4ca9912012-05-08 19:02:07 -070030 /**
31 * @deprecated in API 16
32 **/
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -070033 public enum CullMode {
Jason Samsd4ca9912012-05-08 19:02:07 -070034 /**
35 * @deprecated in API 16
36 **/
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -070037 BACK (0),
Jason Samsd4ca9912012-05-08 19:02:07 -070038 /**
39 * @deprecated in API 16
40 **/
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -070041 FRONT (1),
Jason Samsd4ca9912012-05-08 19:02:07 -070042 /**
43 * @deprecated in API 16
44 **/
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -070045 NONE (2);
46
47 int mID;
48 CullMode(int id) {
49 mID = id;
50 }
51 }
52
Jason Samsebfb4362009-09-23 13:57:02 -070053 boolean mPointSprite;
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -070054 CullMode mCullMode;
Jason Samsebfb4362009-09-23 13:57:02 -070055
Tim Murray460a0492013-11-19 12:45:54 -080056 ProgramRaster(long id, RenderScript rs) {
Alex Sakhartchouk0de94442010-08-11 14:41:28 -070057 super(id, rs);
Jason Samsebfb4362009-09-23 13:57:02 -070058
Jason Samsebfb4362009-09-23 13:57:02 -070059 mPointSprite = false;
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -070060 mCullMode = CullMode.BACK;
Jason Samsebfb4362009-09-23 13:57:02 -070061 }
62
Stephen Hines9c9ad3f8c22012-05-07 15:34:29 -070063 /**
Jason Samsd4ca9912012-05-08 19:02:07 -070064 * @deprecated in API 16
Alex Sakhartchouk918e8402012-04-11 14:04:23 -070065 * Specifies whether vertices are rendered as screen aligned
66 * elements of a specified size
Alex Sakhartchouk7d5f5e72011-10-18 11:08:31 -070067 * @return whether point sprites are enabled
68 */
Alex Sakhartchouk918e8402012-04-11 14:04:23 -070069 public boolean isPointSpriteEnabled() {
Alex Sakhartchouk7d5f5e72011-10-18 11:08:31 -070070 return mPointSprite;
71 }
72
Stephen Hines9c9ad3f8c22012-05-07 15:34:29 -070073 /**
Jason Samsd4ca9912012-05-08 19:02:07 -070074 * @deprecated in API 16
Alex Sakhartchouk918e8402012-04-11 14:04:23 -070075 * Specifies how triangles are culled based on their orientation
Alex Sakhartchouk7d5f5e72011-10-18 11:08:31 -070076 * @return cull mode
77 */
78 public CullMode getCullMode() {
79 return mCullMode;
80 }
81
Jason Samsd4ca9912012-05-08 19:02:07 -070082 /**
83 * @deprecated in API 16
84 */
Alex Sakhartchoukd36f2482010-08-24 11:37:33 -070085 public static ProgramRaster CULL_BACK(RenderScript rs) {
86 if(rs.mProgramRaster_CULL_BACK == null) {
87 ProgramRaster.Builder builder = new ProgramRaster.Builder(rs);
88 builder.setCullMode(CullMode.BACK);
89 rs.mProgramRaster_CULL_BACK = builder.create();
90 }
91 return rs.mProgramRaster_CULL_BACK;
92 }
93
Jason Samsd4ca9912012-05-08 19:02:07 -070094 /**
95 * @deprecated in API 16
96 */
Alex Sakhartchoukd36f2482010-08-24 11:37:33 -070097 public static ProgramRaster CULL_FRONT(RenderScript rs) {
98 if(rs.mProgramRaster_CULL_FRONT == null) {
99 ProgramRaster.Builder builder = new ProgramRaster.Builder(rs);
100 builder.setCullMode(CullMode.FRONT);
101 rs.mProgramRaster_CULL_FRONT = builder.create();
102 }
103 return rs.mProgramRaster_CULL_FRONT;
104 }
105
Jason Samsd4ca9912012-05-08 19:02:07 -0700106 /**
107 * @deprecated in API 16
108 */
Alex Sakhartchoukd36f2482010-08-24 11:37:33 -0700109 public static ProgramRaster CULL_NONE(RenderScript rs) {
110 if(rs.mProgramRaster_CULL_NONE == null) {
111 ProgramRaster.Builder builder = new ProgramRaster.Builder(rs);
112 builder.setCullMode(CullMode.NONE);
113 rs.mProgramRaster_CULL_NONE = builder.create();
114 }
115 return rs.mProgramRaster_CULL_NONE;
116 }
117
Jason Samsd4ca9912012-05-08 19:02:07 -0700118 /**
119 * @deprecated in API 16
120 */
Jason Samsebfb4362009-09-23 13:57:02 -0700121 public static class Builder {
122 RenderScript mRS;
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -0700123 boolean mPointSprite;
Alex Sakhartchoukd36f2482010-08-24 11:37:33 -0700124 CullMode mCullMode;
Jason Samsebfb4362009-09-23 13:57:02 -0700125
Jason Samsd4ca9912012-05-08 19:02:07 -0700126 /**
127 * @deprecated in API 16
128 */
Mathew Inwoodf0c90b12018-08-01 10:05:11 +0100129 @UnsupportedAppUsage
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -0700130 public Builder(RenderScript rs) {
131 mRS = rs;
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -0700132 mPointSprite = false;
Alex Sakhartchoukd36f2482010-08-24 11:37:33 -0700133 mCullMode = CullMode.BACK;
Jason Samsebfb4362009-09-23 13:57:02 -0700134 }
135
Jason Samsd4ca9912012-05-08 19:02:07 -0700136 /**
137 * @deprecated in API 16
138 */
Mathew Inwoodf0c90b12018-08-01 10:05:11 +0100139 @UnsupportedAppUsage
Alex Sakhartchoukb4d7bb62010-12-21 14:42:26 -0800140 public Builder setPointSpriteEnabled(boolean enable) {
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -0700141 mPointSprite = enable;
Jim Shuma288c8712010-07-07 14:24:21 -0700142 return this;
Jason Samsebfb4362009-09-23 13:57:02 -0700143 }
144
Jason Samsd4ca9912012-05-08 19:02:07 -0700145 /**
146 * @deprecated in API 16
147 */
Alex Sakhartchoukd36f2482010-08-24 11:37:33 -0700148 public Builder setCullMode(CullMode m) {
149 mCullMode = m;
150 return this;
151 }
152
Jason Samsd4ca9912012-05-08 19:02:07 -0700153 /**
154 * @deprecated in API 16
155 */
Mathew Inwoodf0c90b12018-08-01 10:05:11 +0100156 @UnsupportedAppUsage
Jason Samsebfb4362009-09-23 13:57:02 -0700157 public ProgramRaster create() {
Jason Sams771bebb2009-12-07 12:40:12 -0800158 mRS.validate();
Tim Murray460a0492013-11-19 12:45:54 -0800159 long id = mRS.nProgramRasterCreate(mPointSprite, mCullMode.mID);
Alex Sakhartchouk7d5f5e72011-10-18 11:08:31 -0700160 ProgramRaster programRaster = new ProgramRaster(id, mRS);
161 programRaster.mPointSprite = mPointSprite;
162 programRaster.mCullMode = mCullMode;
163 return programRaster;
Jason Samsebfb4362009-09-23 13:57:02 -0700164 }
165 }
166
167}
168
169
170
171
172
Alex Sakhartchouk80a4c2c2010-07-12 15:50:32 -0700173