Estoy intentando crear una pantalla de demostración semitransparente que se inicia solo cuando un usuario instala por primera vez mi aplicación. Aquí hay un ejemplo de la aplicación Pulse News:
Galaxy Nexus
Nexus One
En lugar de una función de 'tocar para descartar', quiero que el usuario pueda deslizar un par de páginas de demostración transparentes.
Para mi primer intento, modifiqué una muestra de la biblioteca ViewPagerIndicator . Usé PNG semitransparentes en ImageViews dentro de cada uno de los fragmentos del paginador de vistas. Luego lo lancé como una 'actividad de demostración' en el método onCreate de mi 'actividad principal'.
Problema: La 'actividad principal' no se podía ver de fondo, sino que era simplemente negra. Probé las soluciones aquí , pero eso no solucionó el problema.
¿Existe un mejor enfoque para crear algo como esto, o estoy en el camino correcto?
También tuve otra pregunta relacionada que depende de cómo se implemente. Estoy tratando de superponer texto y flechas de manera que apunten a componentes particulares de la interfaz de usuario en segundo plano. Al usar un PNG que tiene el texto y las flechas, es probable que no se escale correctamente en diferentes dispositivos. Es decir, es posible que las flechas no apunten necesariamente al componente de IU correcto en segundo plano. ¿Hay alguna forma de abordar este problema también?
¡Gracias!
Aquí está mi código para el primer intento:
DemoActivity.java
public class DemoActivity extends FragmentActivity {
DemoFragmentAdapter mAdapter;
ViewPager mPager;
PageIndicator mIndicator;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.demo_activity);
mAdapter = new DemoFragmentAdapter(getSupportFragmentManager());
mPager = (ViewPager)findViewById(R.id.pager);
mPager.setAdapter(mAdapter);
//mPager.setAlpha(0);
UnderlinePageIndicator indicator = (UnderlinePageIndicator)findViewById(R.id.indicator);
indicator.setViewPager(mPager);
indicator.setFades(false);
mIndicator = indicator;
}
}
DemoFragmentAdapter.java
class DemoFragmentAdapter extends FragmentPagerAdapter {
protected static final int[] CONTENT = new int[] { R.drawable.demo1, R.drawable.demo2, R.drawable.demo3, R.drawable.demo4};
private int mCount = CONTENT.length;
public DemoFragmentAdapter(FragmentManager fm) {
super(fm);
}
@Override
public Fragment getItem(int position) {
return DemoFragment.newInstance(CONTENT[position % CONTENT.length]);
}
@Override
public int getCount() {
return mCount;
}
public void setCount(int count) {
if (count > 0 && count <= 10) {
mCount = count;
notifyDataSetChanged();
}
} }
DemoFragment.java
public final class DemoFragment extends Fragment {
private static final String KEY_CONTENT = "TestFragment:Content";
public static DemoFragment newInstance(int content) {
DemoFragment fragment = new DemoFragment();
fragment.mContent = content;
return fragment;
}
private int mContent;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if ((savedInstanceState != null) && savedInstanceState.containsKey(KEY_CONTENT)) {
mContent = savedInstanceState.getInt(KEY_CONTENT);
}
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
ImageView image = new ImageView(getActivity());
image.setBackgroundResource(mContent);
LinearLayout layout = new LinearLayout(getActivity());
layout.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
layout.setGravity(Gravity.CENTER);
layout.addView(image);
return layout;
}
@Override
public void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putInt(KEY_CONTENT, mContent);
}
}