Android ViewPager嵌套GridView实现滚动菜单(demo)
来源:互联网 发布:js 扫描条形码 编辑:程序博客网 时间:2024/06/03 12:28
目前国内的app很常见的一种首页菜单布局就是类似于大众点评等团购网站的首页菜单交,如下图
上边的菜单区域,通常在Android中是将GridView装填到ViewPager中进行显示,网上的例子或多或少都有点小问题,下边写一个小例子来实现一下.
先看效果图
主要代码如下,最后有demo下载链接,代码写的不是很完美,可以再封装一下,但功能没问题
package com.example.gridviewactivity;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import java.util.concurrent.atomic.AtomicInteger;import android.app.Activity;import android.content.Intent;import android.os.Bundle;import android.os.Handler;import android.os.Message;import android.support.v4.view.PagerAdapter;import android.support.v4.view.ViewPager;import android.support.v4.view.ViewPager.OnPageChangeListener;import android.util.DisplayMetrics;import android.view.View;import android.view.View.OnClickListener;import android.view.ViewGroup;import android.view.ViewGroup.LayoutParams;import android.widget.AdapterView;import android.widget.AdapterView.OnItemClickListener;import android.widget.BaseAdapter;import android.widget.GridView;import android.widget.ImageView;import android.widget.LinearLayout;import android.widget.Toast;public class MainActivity extends Activity { private LinearLayout linear01; private LinearLayout linear02; private List<Map<String, Object>> listView; private int next = 0; private ViewPager adViewPager; private AdPageAdapter adapter; private ImageView[] imageViews; private ImageView imageView; private AtomicInteger atomicInteger = new AtomicInteger(0); private boolean isContinue = true; private List<View> gridViewlist = new ArrayList<View>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } private void initView() { linear01 = (LinearLayout) findViewById(R.id.view_pager_content); linear02 = (LinearLayout) findViewById(R.id.viewGroup); listView = new ArrayList<Map<String, Object>>(); // 创建ViewPager adViewPager = new ViewPager(this); DisplayMetrics dm = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); // 设置属性 adViewPager.setLayoutParams(new LayoutParams(dm.widthPixels, dm.heightPixels)); linear01.addView(adViewPager); getView(); initCirclePoint(); // 将GridView添加到ViewPager显示 adViewPager.setAdapter(adapter); adViewPager.setOnPageChangeListener(new AdPageChangeListener()); for (int i = 0; i < gridViewlist.size(); i++) { GridView view = (GridView) gridViewlist.get(i); view.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Map<String, Object> item = (Map<String, Object>) parent.getItemAtPosition(position); Toast.makeText(getApplicationContext(), item.get("image").toString(), 0).show(); } }); } } private final class AdPageChangeListener implements OnPageChangeListener { @Override public void onPageScrollStateChanged(int arg0) { } @Override public void onPageScrolled(int arg0, float arg1, int arg2) { } @Override public void onPageSelected(int arg0) { atomicInteger.getAndSet(arg0); for (int i = 0; i < imageViews.length; i++) { imageViews[arg0].setBackgroundResource(R.drawable.point_focused); if (arg0 != i) { imageViews[i].setBackgroundResource(R.drawable.point_unfocused); } } } } private void initCirclePoint() { System.out.println("initCirclePoint()"); imageViews = new ImageView[gridViewlist.size()]; for (int i = 0; i < gridViewlist.size(); i++) { imageView = new ImageView(this); LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.FILL_PARENT); layoutParams.setMargins(10, 0, 10, 0); imageView.setLayoutParams(layoutParams); imageViews[i] = imageView; if (i == 0) { imageViews[i].setBackgroundResource(R.drawable.point_focused); } else { imageViews[i].setBackgroundResource(R.drawable.point_unfocused); } linear02.addView(imageViews[i]); } } private void getView() { int[] intView = { R.drawable.one, R.drawable.two, R.drawable.three, R.drawable.four, R.drawable.five, R.drawable.six, R.drawable.seven, R.drawable.eight, R.drawable.nine, R.drawable.ten, R.drawable.eleven, R.drawable.twelve, R.drawable.thirteen, R.drawable.fourteen, R.drawable.fifteen, R.drawable.sixteen, R.drawable.seventeen, R.drawable.sixteen, R.drawable.seventeen, R.drawable.sixteen, R.drawable.seventeen, R.drawable.sixteen, R.drawable.seventeen, R.drawable.sixteen, R.drawable.seventeen, R.drawable.sixteen, R.drawable.seventeen, R.drawable.sixteen, R.drawable.seventeen, R.drawable.sixteen, R.drawable.seventeen, R.drawable.seven, R.drawable.eight, R.drawable.seven, R.drawable.eight, R.drawable.seven, R.drawable.eight }; for (int i = 0; i < intView.length; i++) { Map<String, Object> mapView = new HashMap<String, Object>(); mapView.put("image", intView[i]); listView.add(mapView); } getGridView(); } private void getGridView() { System.out.println("getGridView" + listView.size()); boolean bool = true; while (bool) { int result = next + 10; System.out.println("result" + result); if (listView.size() != 0 && result < listView.size()) { System.out.println("result+kkkkkkkkkk" + result); GridView gridView = new GridView(this); gridView.setNumColumns(5); List<Map<String, Object>> gridlist = new ArrayList<Map<String, Object>>(); for (int i = next; i < result; i++) { gridlist.add(listView.get(i)); } MyAdapter myAdapter = new MyAdapter(gridlist); gridView.setAdapter(myAdapter); next = result; gridViewlist.add(gridView); } else if (result - listView.size() <= 10) { List<Map<String, Object>> gridlist = new ArrayList<Map<String, Object>>(); for (int i = next; i < listView.size(); i++) { gridlist.add(listView.get(i)); } GridView gridView = new GridView(this); gridView.setNumColumns(5); MyAdapter myAdapter = new MyAdapter(gridlist); gridView.setAdapter(myAdapter); next = listView.size() - 1; gridViewlist.add(gridView); bool = false; } else { bool = false; } } adapter = new AdPageAdapter(gridViewlist); } private final class AdPageAdapter extends PagerAdapter { private List<View> views = null; public AdPageAdapter(List<View> views) { this.views = views; } @Override public void destroyItem(View container, int position, Object object) { ((ViewPager) container).removeView(views.get(position)); } @Override public int getCount() { return views.size(); } @Override public Object instantiateItem(View container, final int position) { ((ViewPager) container).addView(views.get(position), 0); return views.get(position); } @Override public boolean isViewFromObject(View view, Object object) { return view == object; } } private class MyAdapter extends BaseAdapter { List<Map<String, Object>> listgrid; private MyAdapter(List<Map<String, Object>> listgrid) { this.listgrid = listgrid; } @Override public int getCount() { return listgrid.size(); } @Override public Object getItem(int position) { return listgrid.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { convertView = getLayoutInflater().inflate(R.layout.grid_view_item, null); ImageView getViewLinear = (ImageView) convertView.findViewById(R.id.getViewLinear); getViewLinear.setBackgroundResource(Integer.parseInt(listgrid.get(position).get("image").toString())); return convertView; } }}
demo下载链接
0 0
- Android ViewPager嵌套GridView实现滚动菜单(demo)
- ViewPager嵌套GridView实现分页滚动
- Android嵌套滚动Demo-NestedScrollingChild实现
- Viewpager嵌套GridView的实现
- 通过Fragment + Viewpager+Gridview实现Android Tab切换菜单
- Android 自定义ViewPager嵌套滚动兼容
- ViewPager(横向滑动菜单) 实现Demo
- Viewpager + GridView 嵌套使用
- Android 实现横向标题栏滚动效果(HorizontalScrollView + GridView + Viewpager + 自定义适配器)
- Android GridView实现横向滚动
- Android GridView实现横向滚动
- android ScrollView嵌套viewpager,viewpager嵌套gridview,解决内嵌无法显示的问题
- [Android]ScrollView,ListView,ExpandableListView,ViewPager各种嵌套demo
- Android ViewPager 中嵌套webview 的滚动处理
- Android -下拉刷新,ViewPager和ScrollView嵌套滚动问题解决方案
- ScorollView ViewPager gridView嵌套错误
- Android 嵌套ViewPager实现连贯双滑动
- android 底部菜单tabhost嵌套viewpager+actionbar+menudrawer+圆形图片
- java常量池概念
- a[i++]
- cover letter 和response letter的写法
- 深入浅出Dubbo(一)
- 洛谷 P1541 [NOIP2010 T2] 乌龟棋
- Android ViewPager嵌套GridView实现滚动菜单(demo)
- Java 中使用 MySql以及一些Mysql 基本的命令
- Validation表单验证插件
- 深入浅出Dubbo(二)
- JavaWeb: 报错信息The superclass "javax.servlet.http.HttpServlet" was not found on the Java Build Path
- POJ 1742 Coins
- LeetCode | Rotate List
- python开发简单爬虫:准备篇
- 深入浅出Dubbo(三)