工作中遇到的问题之viewpager实现滑屏效果

在做项目时遇到的问题有:

1.Viewpager 如何实现滑屏

2.View滑动后当前页面颜色改变

3.第一个页面点击Item后当滑倒第三个页面再回到第个页面时,第一个页面点击变色消失,显示默认显示,但点击时的数据被记录(即Viewpager页面存储及销毁问题)恶免

4.随着页面的滑动,下面添加图标,并根据页面的多少显示多少图标,且选中页图标颜色改变

下面代码是解决上述问题时写的代码,不过在做项目是被自己挖的坑给坑了,有一个页面显示问题,我添加了三个页面,只显示第一个页面,后面两个页面怎么也不显示,问了很多人,网上看了很多例子,最后发现自己的子页面显示熟悉设置的是GONE,白白花了两天时间!希望以后自己细心点,也希望搜索问题的童鞋们写代码时一定的细心,bie

 viewPager=(ViewPager) findViewById(R.id.viewpager);  //查找对应xml中的Viewpager

       group=(ViewGroup)findViewById(R.id.viewGroup);//添加根据viewpager 页面多少添加多少图标点,
       
       final ArrayList<View>views=new ArrayList<View>();  
       LayoutInflater inflater=getLayoutInflater();  
       view1=inflater.inflate(R.layout.lay1, null);  //View子页面
       view2=inflater.inflate(R.layout.lay2, null);  

       view3=inflater.inflate(R.layout.lay3, null);  

 views.add(view1);  
       views.add(view2);  
       views.add(view3); 
       imageViews=new ImageView[views.size()];
       for (int i = 0; i < views.size(); i++) {
imageView=new ImageView(this);
imageView.setLayoutParams(new LayoutParams(40,40));  
       imageView.setPadding(40, 0, 40, 0);  
       imageViews[i] = imageView;  
       if (i == 0) {  
               //默认选中第一张图片
               imageViews[i].setBackgroundResource(R.drawable.blue05);  //设置页面下对应的图标
           } else {  
               imageViews[i].setBackgroundResource(R.drawable.hui06);  
           }  
       group.addView(imageViews[i]);
}
       viewPager.setAdapter(new MyViewPagerAdapter(views));  
       isclick=true;
       viewPager.setCurrentItem(0);  
       viewPager.setOffscreenPageLimit(2);//设置记录页面点击数据,即页面可保存三个页面的数据
       viewPager.setOnPageChangeListener(new MyOnPageChangeListener()); 

 public class MyViewPagerAdapter extends PagerAdapter{  
       private List<View> mListViews;  
         
       public MyViewPagerAdapter(List<View> mListViews) {  
           this.mListViews = mListViews;  
       }  
 
       @Override
public int getItemPosition(Object object) {
// TODO Auto-generated method stub
return super.getItemPosition(object);
}


@Override  
       public void destroyItem(ViewGroup container, int position, Object object)   {     
           container.removeView(mListViews.get(position));  
           isclick=false;
       }  
 


@Override  
       public Object instantiateItem(ViewGroup container, int position) {            

  
container.addView(mListViews.get(position),0); 
            
            return mListViews.get(position);  
       }  
 
       @Override  
       public int getCount() {           
           return  mListViews.size();  
       }  
         
       @Override  
       public boolean isViewFromObject(View arg0, Object arg1) {             
           return arg0==arg1;  
       }  
   }  
public class MyOnPageChangeListener implements OnPageChangeListener{  
 
     //当滑动状态改变时调用  
       public void onPageScrollStateChanged(int arg0) {  
//         showView();
//         mPagerAdapter.notifyDataSetChanged();
        isclick=false;
       }  
//       当当前页面被滑动时调用 
       public void onPageScrolled(int arg0, float arg1, int arg2) {  
//         showView();
       // mPagerAdapter.notifyDataSetChanged();
        isclick=false;
       }  
 
       public void onPageSelected(int arg0) {  //设置被选中页面的显示问题
//         showView();
//         mPagerAdapter.notifyDataSetChanged();
        for (int i = 0; i < imageViews.length; i++) {  
                imageViews[arg0].setBackgroundResource(R.drawable.blue05);
                
                if (arg0 != i) {  
                    imageViews[i].setBackgroundResource(R.drawable.hui06);  
                }  
            }
        switch (arg0) {
case 0:
if (isClick3||isClick4) {
ly_yuyin.setBackgroundResource(R.drawable.xuanzhong_red);
ly_flow.setBackgroundResource(R.drawable.weixuanzhong_red);
ly_yewu.setBackgroundResource(R.drawable.weixuanzhong_red);
}else {
ly_yuyin.setBackgroundResource(R.drawable.xuanzhong_red);
ly_flow.setBackgroundResource(R.drawable.weixuanzhong_red);
ly_yewu.setBackgroundResource(R.drawable.weixuanzhong_hui);
}
break;
case 1:
if (isClick3||isClick4) {
ly_yuyin.setBackgroundResource(R.drawable.weixuanzhong_red);
ly_flow.setBackgroundResource(R.drawable.xuanzhong_red);
ly_yewu.setBackgroundResource(R.drawable.weixuanzhong_red);
}else {
ly_yuyin.setBackgroundResource(R.drawable.weixuanzhong_red);
ly_flow.setBackgroundResource(R.drawable.xuanzhong_red);
ly_yewu.setBackgroundResource(R.drawable.weixuanzhong_hui);
}
break;
case 2:
if (isClick3||isClick4) {
ly_yuyin.setBackgroundResource(R.drawable.weixuanzhong_red);
ly_flow.setBackgroundResource(R.drawable.weixuanzhong_red);
ly_yewu.setBackgroundResource(R.drawable.xuanzhong_red);
}else {
ly_yuyin.setBackgroundResource(R.drawable.weixuanzhong_red);
ly_flow.setBackgroundResource(R.drawable.weixuanzhong_red);
ly_yewu.setBackgroundResource(R.drawable.xuanzhong_hui);
}
break;


default:
break;
}
        isclick=false;
       }  
         
   } 

基于SSM框架的智能家政保洁预约系统,是一个旨在提高家政保洁服务预约效率和管理水平的平台。该系统通过集成现代信息技术,为家政公司、家政服务人员和消费者提供了一个便捷的在线预约和管理系统。 系统的主要功能包括: 1. **用户管理**:允许消费者注册、登录,并管理他们的个人资料和预约历史。 2. **家政人员管理**:家政服务人员可以注册并更新自己的个人信息、服务类别和服务时间。 3. **服务预约**:消费者可以浏览不同的家政服务选项,选择合适的服务人员,并在线预约服务。 4. **订单管理**:系统支持订单的创建、跟踪和管理,包括订单的确认、完成和评价。 5. **评价系统**:消费者可以在家政服务完成后对服务进行评价,帮助提高服务质量和透明度。 6. **后台管理**:管理员可以管理用户、家政人员信息、服务类别、预约订单以及处理用户反馈。 系统采用Java语言开发,使用MySQL数据库进行数据存储,通过B/S架构实现用户与服务的在线交互。系统设计考虑了不同用户角色的需求,包括管理员、家政服务人员和普通用户,每个角色都有相应的权限和功能。此外,系统还采用了软件组件化、精化体系结构、分离逻辑和数据等方法,以便于未来的系统升级和维护。 智能家政保洁预约系统通过提供一个集的平台,不仅方便了消费者的预约和管理,也为家政服务人员提供了一个展示和推广自己服务的机会。同时,系统的后台管理功能为家政公司提供了强大的数据支持和决策辅助,有助于提高服务质量和管理效率。该系统的设计与实现,标志着家政保洁服务向现代化和网络化的转型,为管理决策和控制提供保障,是行业发展的重要里程碑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值