/*
* 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 com.android.toolKit.union;
import java.io.Writer;
import java.util.ArrayList;
import javax.microedition.khronos.egl.EGL10;
import javax.microedition.khronos.egl.EGL11;
import javax.microedition.khronos.egl.EGLConfig;
import javax.microedition.khronos.egl.EGLContext;
import javax.microedition.khronos.egl.EGLDisplay;
import javax.microedition.khronos.egl.EGLSurface;
import javax.microedition.khronos.opengles.GL;
import javax.microedition.khronos.opengles.GL10;
import android.content.Context;
import android.content.pm.ConfigurationInfo;
import android.graphics.PixelFormat;
import android.opengl.GLDebugHelper;
//import android.os.SystemProperties;
import android.util.AttributeSet;
import android.util.Log;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
/**
* An implementation of SurfaceView that uses the dedicated surface for
* displaying OpenGL rendering.
* <p>
* A GLSurfaceView provides the following features:
* <p>
* <ul>
* <li>Manages a surface, which is a special piece of memory that can be
* composited into the Android view system.
* <li>Manages an EGL display, which enables OpenGL to render into a surface.
* <li>Accepts a user-provided Renderer object that does the actual rendering.
* <li>Renders on a dedicated thread to decouple rendering performance from the
* UI thread.
* <li>Supports both on-demand and continuous rendering.
* <li>Optionally wraps, traces, and/or error-checks the renderer's OpenGL calls.
* </ul>
*
* <h3>Using GLSurfaceView</h3>
* <p>
* Typically you use GLSurfaceView by subclassing it and overriding one or more of the
* View system input event methods. If your application does not need to override event
* methods then GLSurfaceView can be used as-is. For the most part
* GLSurfaceView behavior is customized by calling "set" methods rather than by subclassing.
* For example, unlike a regular View, drawing is delegated to a separate Renderer object which
* is registered with the GLSurfaceView
* using the {@link #setRenderer(Renderer)} call.
* <p>
* <h3>Initializing GLSurfaceView</h3>
* All you have to do to initialize a GLSurfaceView is call {@link #setRenderer(Renderer)}.
* However, if desired, you can modify the default behavior of GLSurfaceView by calling one or
* more of these methods before calling setRenderer:
* <ul>
* <li>{@link #setDebugFlags(int)}
* <li>{@link #setEGLConfigChooser(boolean)}
* <li>{@link #setEGLConfigChooser(EGLConfigChooser)}
* <li>{@link #setEGLConfigChooser(int, int, int, int, int, int)}
* <li>{@link #setGLWrapper(GLWrapper)}
* </ul>
* <p>
* <h4>Specifying the android.view.Surface</h4>
* By default GLSurfaceView will create a PixelFormat.RGB_565 format surface. If a translucent
* surface is required, call getHolder().setFormat(PixelFormat.TRANSLUCENT).
* The exact format of a TRANSLUCENT surface is device dependent, but it will be
* a 32-bit-per-pixel surface with 8 bits per component.
* <p>
* <h4>Choosing an EGL Configuration</h4>
* A given Android device may support multiple EGLConfig rendering configurations.
* The available configurations may differ in how may channels of data are present, as
* well as how many bits are allocated to each channel. Therefore, the first thing
* GLSurfaceView has to do when starting to render is choose what EGLConfig to use.
* <p>
* By default GLSurfaceView chooses a EGLConfig that has an RGB_656 pixel format,
* with at least a 16-bit depth buffer and no stencil.
* <p>
* If you would prefer a different EGLConfig
* you can override the default behavior by calling one of the
* setEGLConfigChooser methods.
* <p>
* <h4>Debug Behavior</h4>
* You can optionally modify the behavior of GLSurfaceView by calling
* one or more of the debugging methods {@link #setDebugFlags(int)},
* and {@link #setGLWrapper}. These methods may be called before and/or after setRenderer, but
* typically they are called before setRenderer so that they take effect immediately.
* <p>
* <h4>Setting a Renderer</h4>
* Finally, you must call {@link #setRenderer} to register a {@link Renderer}.
* The renderer is
* responsible for doing the actual OpenGL rendering.
* <p>
* <h3>Rendering Mode</h3>
* Once the renderer is set, you can control whether the renderer draws
* continuously or on-demand by calling
* {@link #setRenderMode}. The default is continuous rendering.
* <p>
* <h3>Activity Life-cycle</h3>
* A GLSurfaceView must be notified when the activity is paused and resumed. GLSurfaceView clients
* are required to call {@link #onPause()} when the activity pauses and
* {@link #onResume()} when the activity resumes. These calls allow GLSurfaceView to
* pause and resume the rendering thread, and also allow GLSurfaceView to release and recreate
* the OpenGL display.
* <p>
* <h3>Handling events</h3>
* <p>
* To handle an event you will typically subclass GLSurfaceView and override the
* appropriate method, just as you would with any other View. However, when handling
* the event, you may need to communicate with the Renderer object
* that's running in the rendering thread. You can do this using any
* standard Java cross-thread communication mechanism. In addition,
* one relatively easy way to communicate with your renderer is
* to call
* {@link #queueEvent(Runnable)}. For example:
* <pre class="prettyprint">
* class MyGLSurfaceView extends GLSurfaceView {
*
* private MyRenderer mMyRenderer;
*
* public void start() {
* mMyRenderer = ...;
* setRenderer(mMyRenderer);
* }
*
* public boolean onKeyDown(int keyCode, KeyEvent event) {
* if (keyCode == KeyEvent.KEYCODE_DPAD_CENTER) {
* queueEvent(new Runnable() {
* // This method will be called on the rendering
* // thread:
* public void run() {
* mMyRenderer.handleDpadCenter();
* }});
* return true;
* }
* return super.onKeyDown(keyCode, event);
* }
* }
* </pre>
*
*/
public class Code_GLSurfaceView extends SurfaceView implements SurfaceHolder.Callback {
private final static boolean LOG_THREADS = false;
private final static boolean LOG_PAUSE_RESUME = false;
private final static boolean LOG_SURFACE = false;
private final static boolean LOG_RENDERER = false;
private final static boolean LOG_RENDERER_DRAW_FRAME = false;
private final static boolean LOG_EGL = false;
// Work-around for bug 2263168
private final static boolean DRAW_TWICE_AFTER_SIZE_CHANGED = true;
/**
* The renderer only renders
* when the surface is created, or when {@link #requestRender} is called.
*
* @see #getRenderMode()
* @see #setRenderMode(int)
* @see #requestRender()
*/
public final static int RENDERMODE_WHEN_DIRTY = 0;
/**
* The renderer is called
* continuously to re-render the scene.
*
* @see #getRenderMode()
* @see #setRenderMode(int)
*/
public final static int RENDERMODE_CONTINUOUSLY = 1;
/**
* Check glError() after every GL call and throw an exception if glError indicates
* that an error has occurred. This can be used to help track down which OpenGL ES call
* is causing an error.
*
* @see #getDebugFlags
* @see #setDebugFlags
*/
没有合适的资源?快使用搜索试试~ 我知道了~
Launcher 桌面 安卓桌面应用EyeRoom(程序源码).zip
共1169个文件
s3dm:340个
png:297个
java:196个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 191 浏览量
2023-03-16
11:03:43
上传
评论
收藏 24.82MB ZIP 举报
温馨提示
免责声明:资料部分来源于合法的互联网渠道收集和整理,部分自己学习积累成果,供大家学习参考与交流。收取的费用仅用于收集和整理资料耗费时间的酬劳。 本人尊重原创作者或出版方,资料版权归原作者或出版方所有,本人不对所涉及的版权问题或内容负法律责任。如有侵权,请举报或通知本人删除。
资源推荐
资源详情
资源评论
收起资源包目录
Launcher 桌面 安卓桌面应用EyeRoom(程序源码).zip (1169个子文件)
textureuvmove.bmp 768KB
iroom_material_namecard.bmp 768KB
textureuvmove.bmp 768KB
iroom_material_namecard.bmp 768KB
textureuvmove.bmp 768KB
iroom_material_namecard.bmp 768KB
iroom_material_namecard.bmp 768KB
iroom_bmp_09gameoutpiece.bmp 512KB
iroom_bmp_02message.bmp 512KB
iroom_bmp_01namecard.bmp 512KB
iroom_bmp_game_tab02_bg.bmp 512KB
iroom_bmp_09game_bg.bmp 512KB
goicons_bmp_mailicon.bmp 512KB
iroom_bmp_09gameoutpiece.bmp 512KB
iroom_bmp_02message.bmp 512KB
iroom_bmp_01namecard.bmp 512KB
iroom_bmp_09game_bg.bmp 512KB
goicons_bmp_mailicon.bmp 512KB
iroom_bmp_game_tab02_bg.bmp 512KB
iroom_bmp_02message.bmp 512KB
iroom_bmp_09gameoutpiece.bmp 512KB
iroom_bmp_01namecard.bmp 512KB
iroom_bmp_09game_bg.bmp 512KB
goicons_bmp_mailicon.bmp 512KB
iroom_bmp_game_tab02_bg.bmp 512KB
iroom_bmp_statusbar.bmp 512KB
iroom_bmp_02message.bmp 512KB
iroom_bmp_01namecard.bmp 512KB
goicons_bmp_mailicon.bmp 512KB
iroom_bmp_07phone.bmp 128KB
iroom_bmp_07phone.bmp 128KB
iroom_bmp_07phone.bmp 128KB
iroom_bmp_09gameoutpiece.bmp 128KB
iroom_bmp_09game.bmp 128KB
iroom_bmp_09game_bg.bmp 128KB
iroom_bmp_07phone.bmp 128KB
iroom_material_icons.bmp 111KB
iroom_material_icons.bmp 111KB
iroom_material_icons.bmp 111KB
iroom_material_icons.bmp 111KB
iroom_bmp_game_tab02_bg.bmp 88KB
iroom_bmp_05icons.bmp 32KB
iroom_bmp_07phoneprofile.bmp 32KB
iroom_bmp_05icons.bmp 32KB
iroom_bmp_07phoneprofile.bmp 32KB
iroom_bmp_05icons.bmp 32KB
iroom_bmp_07phoneprofile.bmp 32KB
iroom_bmp_05icons.bmp 32KB
iroom_bmp_07phoneprofile.bmp 32KB
iroom_bmp_game_tab_btn02.bmp 9KB
iroom_bmp_game_tab_btn04.bmp 9KB
iroom_bmp_game_tab_btn01.bmp 9KB
iroom_bmp_game_tab_btn03.bmp 9KB
iroom_bmp_game_tab_btn02.bmp 9KB
iroom_bmp_game_tab_btn04.bmp 9KB
iroom_bmp_game_tab_btn01.bmp 9KB
iroom_bmp_game_tab_btn03.bmp 9KB
iroom_bmp_game_tab_btn02.bmp 9KB
iroom_bmp_game_tab_btn04.bmp 9KB
iroom_bmp_game_tab_btn01.bmp 9KB
iroom_bmp_game_tab_btn03.bmp 9KB
iroom_bmp_game_tab_btn02.bmp 3KB
iroom_bmp_game_tab_btn04.bmp 3KB
iroom_bmp_game_tab_btn01.bmp 3KB
iroom_bmp_game_tab_btn03.bmp 3KB
default_bmp.bmp 104B
default_bmp.bmp 104B
default_bmp.bmp 104B
default_bmp.bmp 104B
注意事项V1.docx 6KB
i2cpix 26KB
weibo.sdk.android.sso.jar 94KB
weibo.sdk.android.sso.jar 94KB
Code_GLSurfaceView.java 68KB
Quaternion.java 41KB
GoMenuSe.java 36KB
OpenGLRenderer.java 35KB
iRoom_MusicPlayer.java 35KB
IroomContactPrepare.java 33KB
IroomAudioPlayerPrepare.java 33KB
IRoomWeiboPrepare.java 31KB
IroomSmsPrepare.java 29KB
HanziToPinyin.java 28KB
iRoom_Message.java 28KB
iRoom_Namecard.java 25KB
IroomMenuAppListView.java 23KB
overallViewState.java 23KB
UtilityToolKit.java 21KB
iRoom_IconClock.java 18KB
IRoomView.java 17KB
IRoomActivity.java 16KB
WidgetInTheEyeStateSequence.java 14KB
WeatherResource.java 13KB
IRoomLoadApp.java 12KB
PhoneFBOLinkNode.java 12KB
Mesh.java 10KB
iRoom_Weather.java 10KB
PanelTpController.java 10KB
compositeNode.java 10KB
GameFBOLinkNode.java 10KB
共 1169 条
- 1
- 2
- 3
- 4
- 5
- 6
- 12
资源评论
金枝玉叶9
- 粉丝: 198
- 资源: 7637
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 串联式、并联式、混联式混合动力系统simulink控制策略模型(串联式、并联式、混联式每个都是独立的需要单独说拿哪个,默认是混联式RB) 有基于逻辑门限值、状态机的规则控制策略(RB)、基于等效燃油
- 法码滋.exe法码滋2.exe法码滋3.exe
- python-geohash-0.8.5-cp38-cp38-win-amd64
- Matlab根据flac、pfc或其他软件导出的坐标及应力、位移数据再现云图 案例包括导出在flac6.0中导出位移的fish代码(也可以自己先准备软件导出的坐标数据及对应点的位移或应力数据,可根据需
- 拳皇97.exe拳皇972.exe拳皇973.exe
- 捕鱼达人1.exe捕鱼达人2.exe捕鱼达人3.exe
- 医疗骨折摄像检测29-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma数据集合集.rar
- ks滑块加密算法与源代码
- 医护人员检测23-YOLOv8数据集合集.rar
- 1.电力系统短路故障引起电压暂降 2.不对称短路故障分析 包括:共两份自编word+相应matlab模型 1.短路故障的发生频次以及不同类型短路故障严重程度,本文选取三类典型的不对称短路展开研究
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功