Estou tentando criar uma tela de demonstração semitransparente que é iniciada apenas quando um usuário instala meu aplicativo pela primeira vez. Aqui está um exemplo do aplicativo Pulse News:
Galaxy Nexus
Nexus One
Em vez de um recurso 'tocar para dispensar', quero que o usuário possa deslizar por algumas dessas páginas de demonstração transparentes.
Para minha primeira tentativa, modifiquei um exemplo da biblioteca ViewPagerIndicator . Usei PNGs semitransparentes em ImageViews dentro de cada um dos fragmentos do pager de visualização. Em seguida, lancei isso como uma 'atividade de demonstração' no método onCreate da minha 'atividade principal'.
Problema: a 'atividade principal' não podia ser vista no fundo - em vez disso, era apenas preto. Tentei as soluções aqui , mas isso não resolveu o problema.
Existe uma abordagem melhor para criar algo assim ou estou no caminho certo?
Eu também tinha outra pergunta relacionada que depende de como isso é implementado. Estou tentando sobrepor o texto e as setas de forma que apontem para componentes de IU específicos no plano de fundo. Ao usar um PNG com texto e setas, é provável que ele não seja dimensionado corretamente em dispositivos diferentes. Ou seja, as setas podem não necessariamente apontar para o componente de IU correto no plano de fundo. Existe uma maneira de resolver esse problema também?
Obrigado!
Este é meu código para a primeira tentativa:
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);
}
}