android----(分组、图片滑动)
来源:互联网 发布:爽肤水作用 知乎 编辑:程序博客网 时间:2024/05/16 06:14
整体思路:
1.要给ExpandableListView 设置适配器,那么必须先设置数据源
2.数据源,就是此处的适配品类ExpandaBleAdapter,此方法继承了BaseExpandableListAdapter ,这是ExpandableListView的子类,需要重写里面的多个方法,
数据源中,用到了自定义的View布局此时根据自己的需求,来设置线和子项的布局样式 ,
getChildView() 和 getGroupView() 方法设置自定义布局
数据源设置好,直接给ExpandableListView.setAdapter()即可实现此收缩功能
1.main_layout<ExpandableListView android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/expandableListView" android:layout_alignParentTop="true" android:layout_alignParentStart="true" />2.gruop_layout.xml child_layout也一样<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_vertical" > <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/icon" android:src="@mipmap/ic_launcher" android:maxWidth="64dp" android:maxHeight="64dp" android:adjustViewBounds="true" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/title" android:text="not data" /></LinearLayout>3.核心代码:public class MainActivity extends Activity { private ExpandableListView listView; //组名称 private String[] groups = {"好友","学校"}; //每一组中的内容 private String[][] childs = {{"猪猪","淡淡","默认"},{"老师","到头","呵呵"}}; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); listView = (ExpandableListView)findViewById(R.id.expandableListView); listView.setAdapter(new MyExpandableAdapter()); //单击事件 listView.setOnChildClickListener(new ExpandableListView.OnChildClickListener() { @Override public boolean onChildClick(ExpandableListView parent, View v, int groupPosition, int childPosition, long id) { Toast.makeText(MainActivity.this,childs[groupPosition][childPosition],Toast.LENGTH_SHORT).show(); return true; } }); } //适配器 class MyExpandableAdapter extends BaseExpandableListAdapter{ @Override public int getGroupCount() { return groups.length; } @Override public int getChildrenCount(int groupPosition) { return childs[groupPosition].length; } @Override public Object getGroup(int groupPosition) { return groups[groupPosition]; } @Override public Object getChild(int groupPosition, int childPosition) { return childs[groupPosition][childPosition]; } @Override public long getGroupId(int groupPosition) { return groupPosition; } @Override public long getChildId(int groupPosition, int childPosition) { return childPosition; } @Override public boolean hasStableIds() { return false; } @Override public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) { if(convertView == null){ convertView = getLayoutInflater().inflate(R.layout.group_layout,null); } ImageView icon = (ImageView) convertView.findViewById(R.id.icon); TextView title = (TextView) convertView.findViewById(R.id.title); title.setText(groups[groupPosition]); // icon.setImageResource(); return convertView; } @Override public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) { if(convertView == null){ convertView = getLayoutInflater().inflate(R.layout.child_layout,null); } ImageView icon = (ImageView) convertView.findViewById(R.id.icon); TextView title = (TextView) convertView.findViewById(R.id.title); title.setText(childs[groupPosition][childPosition]); return convertView; } //组下的成员是否可以选中 @Override public boolean isChildSelectable(int groupPosition, int childPosition) { return true; } }}
ImageSwitcher是Android中控制图片展示效果的一个控件,如幻灯片效果
ImageSwitcher粗略的理解就是ImageView的选择器
ImageSwither的原理:ImageSwitcher有两个子View:ImageView,当左右滑动的时候,就在这两个ImageView之间来回切换来显示图片
既然有两个子ImageView,那么我们要创建两个ImageView给ImageSwitcher。创建ImageSwitcher是通过工厂来实现的 ViewFactory
ImageSwitcher:切换图片 和文本切换一样
1.创建ImageSwitcher组件2.将图片放于mipmap中3.核心代码:public class Switch extends Activity implements ViewSwitcher.ViewFactory,View.OnTouchListener{ private ImageSwitcher imageSwitcher; //图片数据 private int[] images = {R.mipmap.a,R.mipmap.b,R.mipmap.c,R.mipmap.d,R.mipmap.e,R.mipmap.f}; private int index; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_imge_switchers); imageSwitcher = (ImageSwitcher)findViewById(R.id.imageSwitcher2); imageSwitcher.setOnTouchListener(this); imageSwitcher.setFactory(this); }//每一张图片视图 @Override public View makeView() { ImageView iv = new ImageView(this); iv.setImageResource(images[0]); return iv; } float startX = 0.0f; float endX = 0.0f; //触屏事件 @Override public boolean onTouch(View v, MotionEvent event) { int action = event.getAction();//获取当前的事件动作 if(action == MotionEvent.ACTION_DOWN){ startX = event.getX(); imageSwitcher.setInAnimation(this,android.R.anim.fade_in);//图片进的动画 imageSwitcher.setInAnimation(this,android.R.anim.fade_out);//图片出的动画 return true; } if(action == MotionEvent.ACTION_UP){ endX = event.getX(); if(startX - endX>20){//下一张 index = index +1 <images.length?++index:0; imageSwitcher.setInAnimation(this,android.R.anim.fade_in);//图片进的动画 imageSwitcher.setInAnimation(this,android.R.anim.fade_out);//图片出的动画 }else if(endX -startX >20){//上一张 index = index - 1>=0?--index:images.length-1; imageSwitcher.setInAnimation(this,android.R.anim.fade_in);//图片进的动画 imageSwitcher.setInAnimation(this,android.R.anim.fade_out);//图片出的动画 } imageSwitcher.setImageResource(images[index]); } return true; }}
flipper.xml: <ViewFlipper android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/viewFlipper" android:layout_alignParentTop="true" android:layout_alignParentStart="true" /> //第一页 <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent"> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:scaleType="centerCrop" android:src="@mipmap/a" /> </LinearLayout> //第二页 <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent"> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:scaleType="centerCrop" android:src="@mipmap/b" /> </LinearLayout> //第三页 <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent"> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:scaleType="centerCrop" android:src="@mipmap/c"/> </LinearLayout>2.核心代码public class flipper extends Activity { private ViewFlipper viewFlipper; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_flipper); viewFlipper = (ViewFlipper) findViewById(R.id.viewFlipper); } float startX,endX; @Override public boolean onTouchEvent(MotionEvent event) { int action = event.getAction(); if(action == MotionEvent.ACTION_DOWN){ startX = event.getX(); }else if(action == MotionEvent.ACTION_UP){ if(event.getX()>startX){//向右滑动 viewFlipper.setInAnimation(this,R.anim.in_leftright); viewFlipper.setOutAnimation(this,R.anim.out_leftright); viewFlipper.showNext(); }else if(event.getX()<startX){//向左滑动 viewFlipper.setInAnimation(this,R.anim.in_leftright); viewFlipper.setOutAnimation(this,R.anim.out_leftright); viewFlipper.showPrevious(); } } return super.onTouchEvent(event); }}
0 0
- android----(分组、图片滑动)
- 仿优酷Android客户端图片左右滑动(自动滑动)
- Android仿优酷客户端图片左右滑动(自动滑动)
- 仿优酷Android客户端图片左右滑动(自动滑动)
- android Gallery滑动图片
- android图片向右滑动
- Android-ViewPager滑动图片
- android 悬浮图片滑动
- Android 图片滑动练习
- Android ViewPager图片滑动
- Android 图片滑动,小圆点跟着滑动
- Android 图片全屏滑动效果
- Android Gallery图片一张张滑动
- Android Gallery图片一张张滑动
- Android 图片全屏滑动效果
- Android 图片左右滑动效果
- Android实现滑动图片(ViewPager)
- 【android开发】图片滑动_1
- socket学习笔记
- 成员变量和局部变量
- HashMap深度解析(一)
- 自定义 target action
- 【数据结构】线性结构:存储&运算&时间复杂度
- android----(分组、图片滑动)
- C#学习日记12---数据类型 之 引用类型(前言)
- 一直二叉树的前序遍历和中序遍历的结果,重建该二叉树 Java代码实现
- redis文章收藏
- 全面理解Unity加载和内存管理
- 第一个Objective-C程序,如何声明、实现
- Java Web学习笔记之4.HTML标记语言
- Mediaplayer start called in state 0
- Spring MVC 学习笔记(一) 基于spring2.5的纯xml配置