Моя настройка такова: TabHost имеет два дочерних действия, каждый из которых имеет один GLSurfaceView как контент. Эти две операции, разумеется, перенаправляют свои события onPause() и onResume() на их GLSurfaceViews.Настройка нескольких действий, каждая из которых содержит GLSurfaceView в TabHost
Первое действие работает, как и ожидалось, однако переход на другую вкладку не оказывает визуального воздействия. LogCat показывает, что оба объекта onSurfaceCreated(), onSurfaceChanged() и onSurfaceDraw() все вызваны, как ожидалось, на обоих экземплярах GLSurfaceView.
«Исправить» - установить видимость каждого GLSurfaceView с помощью setVisibility (View.INVISIBLE/VISIBLE) в onPause() и onResume() соответственно. Это приводит к тому, что правильные представления отображаются, но при изменении вкладки имеет место искажение эффекта. Это особенно заметно, когда GLSurfaceView выполняет больше работы.
По существу, как я могу избежать установки ВИДИМОСТИ GLSurfaceViews?
TabActivity:
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.mainactivity);
TabHost tabHost = getTabHost();
TabHost.TabSpec spec;
Intent intent;
// First Vortex view
intent = new Intent().setClass(this, VortexActivity.class);
spec = tabHost.newTabSpec("A")
.setIndicator("A")
.setContent(intent);
tabHost.addTab(spec);
// Second Vortex view
intent = new Intent().setClass(this, VortexActivity.class);
spec = tabHost.newTabSpec("B")
.setIndicator("B")
.setContent(intent);
tabHost.addTab(spec);
}
Детский активность:
public class VortexActivity extends Activity {
private GLSurfaceView view;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
view = new GLSurfaceView(this);
view.setRenderer(new VortexRenderer());
setContentView(view);
}
@Override
public void onResume() {
super.onResume();
view.onResume();
//view.setVisibility(View.VISIBLE);
}
@Override
public void onPause() {
super.onPause();
view.onPause();
//view.setVisibility(View.INVISIBLE);
}
}
Renderer:
public class VortexRenderer implements GLSurfaceView.Renderer {
public void onSurfaceCreated(GL10 glArgument, EGLConfig config) {
}
public void onSurfaceChanged(GL10 gl, int w, int h) {
}
public void onDrawFrame(GL10 gl) {
long ms = System.currentTimeMillis() % 2000;
if(ms > 1000)
ms = 1000 - (ms - 1000);
float intensity = ms/500.0f;
gl.glClearColor(intensity, intensity, intensity, 1.0f);
gl.glClear(GL10.GL_COLOR_BUFFER_BIT);
}
}
Планировка:
<?xml version="1.0" encoding="utf-8"?>
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical"
android:padding="0dp" >
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:padding="0dp" />
<TabWidget
android:id="@android:id/tabs"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_weight="0"
android:padding="0dp" />
</LinearLayout>
Как бы вы делили GLSurfaceView между действиями, хотя? Насколько я знаю, вам не разрешено «изменять» родительскую активность в представлении. (Http://stackoverflow.com/questions/7813306/how-can-i-pass-image-view-between-activities-in- android) – Rodskjegg
А, справедливо. Я думал, что они просто детские макеты, а не фактические занятия. –