Я намагаюся створити напівпрозорий демонстраційний екран, який запускається лише тоді, коли користувач вперше встановить мою програму. Ось приклад програми Pulse News:
Galaxy Nexus
Nexus One
Замість функції "натиснути для відхилення" я хочу, щоб користувач міг прогортати пару таких прозорих демонстраційних сторінок.
Для моєї першої спроби я змінив зразок з бібліотеки ViewPagerIndicator . Я використовував напівпрозорі PNG в ImageViews всередині фрагментів пейджера програми перегляду. Потім я запустив це як "демо-активність" у методі onCreate своєї "основної діяльності".
Проблема: "Основну діяльність" не можна було побачити на задньому плані - натомість вона була просто чорною. Я спробував рішення тут , але це не вирішило проблему.
Чи є кращий підхід до створення подібного, чи я на вірному шляху?
У мене також було ще одне пов'язане питання, яке залежить від того, як це здійснюється. Я намагаюся накласти текст і стрілки таким чином, щоб вони вказували на конкретні компоненти інтерфейсу у фоновому режимі. Використовуючи PNG, у якому є текст та стрілки, цілком ймовірно, що він не буде належним чином масштабувати на різних пристроях. Тобто стрілки не обов'язково вказують на правильний компонент інтерфейсу на задньому плані. Чи є також спосіб вирішити цю проблему?
Дякую!
Ось мій код для першої спроби:
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);
}
}