Android:ViewPagerIndicator - 为不同的页面创建不同的布局

时间:2012-05-22 00:34:31

标签: android android-viewpager viewpagerindicator

我需要创建四种不同的布局,每种布局都是一个ViewPagerIndicator页面。 我怎样才能做到这一点? ViewPagerIndicator已经在运行,但我正在使用http://viewpagerindicator.com中的示例,并为所有页面创建了一个简单的TextView。

参见示例(TestFragment.java):

  @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

    TextView text = new TextView(getActivity());
    text.setGravity(Gravity.CENTER);
    text.setText(mContent);
    text.setTextSize(20 * getResources().getDisplayMetrics().density);
    text.setPadding(20, 20, 20, 20);

    LinearLayout layout = new LinearLayout(getActivity());
    layout.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
    layout.setGravity(Gravity.CENTER);
    layout.addView(text);

    return layout;
}

我需要识别当前页面(位置)并参考相关的资源布局(XML)。有可能吗?

我还需要确保在创建活动时一次只加载所有页面的所有视图,以便稍后更新值。

我感谢任何帮助!! 感谢

1 个答案:

答案 0 :(得分:6)

我找到了一个适合我的简单解决方案。这就是我做的。

<强> TestFragment.class

      public static TestFragment newInstance(String content) {
        TestFragment fragment = new TestFragment();
//
//        StringBuilder builder = new StringBuilder();
//        for (int i = 0; i < 20; i++) {
//            builder.append(content).append(" ");
//        }
//        builder.deleteCharAt(builder.length() - 1);
        fragment.mContent = content;

        return fragment;
    }

在这里注释for循环。只需获取我们将用作旗帜的 mContent

现在您的onCreateView()更改内容如下,

   @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
//        TextView text = new TextView(getActivity());
//        text.setGravity(Gravity.CENTER);
//        text.setText(mContent);
//        text.setTextSize(20 * getResources().getDisplayMetrics().density);
//        text.setPadding(20, 20, 20, 20);
//
//        LinearLayout layout = new LinearLayout(getActivity());
//        layout.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
//        layout.setGravity(Gravity.CENTER);
//        layout.addView(text);
        Log.i("mContent",mContent);
        View view=null;
        if(mContent.equalsIgnoreCase("title1"))
        {
            view = inflater.inflate(R.layout.one, container, false);

        }
        else if(mContent.equalsIgnoreCase("title2"))
        {
            view = inflater.inflate(R.layout.two, container, false);
        }
        else if(mContent.equalsIgnoreCase("title3"))
        {
            view = inflater.inflate(R.layout.three, container, false);
        }
        return view;

    }

这就是全部。现在,您可以根据我们用作标志的标题名称来扩展您的视图。