您的位置:首页 > 其它

使用ViewPager+GridView实现横向滑动的效果(二)

2013-07-18 11:00 676 查看
                   上一篇文章初步学习了使用ViewPager(http://blog.csdn.net/jiangqq781931404/article/details/9363919)

            现在正是开始使用ViewPager+GridView方法实现横向滑动效果;

                   


                  上面就是实现的效果,当然用手去滑动,是可以进行横向滑动,到时候有兴趣的可以把例子代码部署到手机中进行测试一下:

            实现该效果的方法,其实还是比较简单的

           1:在布局文件中加入<android.support.v4.view.ViewPager

        android:paddingTop="250dip"

        android:layout_height="wrap_content"

        android:layout_width="wrap_content"        

        android:id="@+id/myviewpager"

        android:layout_weight="7"

        android:layout_gravity="center_vertical"

        android:clickable="true"

        android:focusable="true"

        />    引入ViewPager包

          2:然后创建出GridView把数据添加进去,

          3:使用ViewPager进行显示

         

         接下去直接看代码直截了当

         MainActivity.java

         /**
* 实现自定义ViewPager+GridView
* @author jiangqq
* @time 2013/07/17 17:55
*/
public class MainActivity extends Activity {
private MyViewPagerAdapter adapter;
private List<GridView> mLists;
private ViewPager mViewPager;
private String[] mStrs = new String[] { "01", "02", "03", "04", "05", "06",
"07", "08", "09", "10", "11", "12", "13", "14", "15", "16", "17",
"18", "19", "20", "21", "22", "23", "24", "25", "26", "27", "28",
"29", "30", "31", "32", "33", "34", "35", "36", "37", "38", "39",
"40", "41", "42", "43", "44", "45", "46", "47", "48", "49", "50",
"51", "52", "53", "54", "55", "56", "57", "58", "59", "60" };
private int index = 0;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
init();
mViewPager = (ViewPager) findViewById(R.id.myviewpager);
mViewPager.setOnPageChangeListener(new MyOnPageChanger());
adapter = new MyViewPagerAdapter(this, mLists);
mViewPager.setAdapter(adapter);

}

public void init() {

final int PageCount = (int) Math.ceil(mStrs.length / 28.0f);
mLists = new ArrayList<GridView>();

for (int i = 0; i < PageCount; i++) {
GridView gv = new GridView(this);
gv.setAdapter(new MyGridViewAdapter(this, mStrs, i));
gv.setGravity(Gravity.CENTER);
gv.setClickable(true);
gv.setFocusable(true);
gv.setNumColumns(7);
gv.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> arg0, View arg1,
int arg2, long arg3) {
Toast.makeText(MainActivity.this,
"正在播放第" + mStrs[index*28+arg2] + "集",
Toast.LENGTH_SHORT).show();
}
});
mLists.add(gv);
}
}

/**
* ViewPager页面选项卡进行切换时候的监听器处理
* @author jiangqingqing
*
*/
class MyOnPageChanger implements OnPageChangeListener
{
@Override
public void onPageScrollStateChanged(int arg0) {
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {

}
@Override
public void onPageSelected(int arg0) {

index=arg0;
Log.i("jiangqq", "当前在第"+index+"页");
}

}     MyViewPagerAdapter.java  ViewPager页面适配器
  /**
* 实现ViewPager页卡
* @author jiangqq
*
*/
public class MyViewPagerAdapter extends PagerAdapter{
private List<GridView> mLists;
public MyViewPagerAdapter(Context context, List<GridView> array) {
this.mLists=array;
}
@Override
public int getCount() {
return mLists.size();
}

@Override
public boolean isViewFromObject(View arg0, Object arg1) {

return arg0 == arg1;
}
@Override
public Object instantiateItem(View arg0, int arg1)
{
((ViewPager) arg0).addView(mLists.get(arg1));
return mLists.get(arg1);
}

@Override
public void destroyItem(View arg0, int arg1, Object arg2)
{
((ViewPager) arg0).removeView((View) arg2);
}
    GridView自定义适配器
  public class MyGridViewAdapter extends BaseAdapter {

private Context mContext;
private List<String> mLists;
public static final int PAGE_SIZE = 28; // 每一屏幕显示28 Button
public MyGridViewAdapter(Context pContext, String[] pStrs, int page) {
this.mContext = pContext;
mLists = new ArrayList<String>();
int i = page *PAGE_SIZE;
int end = i +PAGE_SIZE;
while ((i < pStrs.length) && (i < end)) {
mLists.add(pStrs[i]);
i++;
}
}
@Override
public int getCount() {

return mLists.size();
}
@Override
public Object getItem(int position) {

return mLists.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {

Holder _Holder = null;
if (null == convertView) {
_Holder = new Holder();
LayoutInflater mInflater = LayoutInflater.from(mContext);
convertView = mInflater.inflate(R.layout.gridview_item, null);
_Holder.btn_gv_item = (Button) convertView
.findViewById(R.id.btn_gv_item);
_Holder.btn_gv_item.setFocusable(false);
convertView.setTag(_Holder);
} else {
_Holder = (Holder) convertView.getTag();
}
_Holder.btn_gv_item.setText(mLists.get(position));

return convertView;
}

private static class Holder {
Button btn_gv_item;
}
     
     上面也是主要代码,详细例子代码已经上传:

      http://download.csdn.net/detail/jiangqq781931404/5774891

                   
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  ViewPager GridView
相关文章推荐