android ViewPager,ViewFlipper,ViewFlow实现左右滑动

2024-06-18 02:32

本文主要是介绍android ViewPager,ViewFlipper,ViewFlow实现左右滑动,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

开篇

        首页只是作为ViewPager,ViewFlipper,ViewFlow的入口,提供三个Button进行跳转。

               

1. ViewPager

        先看看官方文档怎么介绍ViewPager的:http://developer.android.com/reference/android/support/v4/view/ViewPager.html

        继承关系如下:

        java.lang.Object 

             android.view.View 

                   android.view.ViewGroup 

                        android.support.v4.view.ViewPager

        ViewPager做为容器类,可以结合View(Layout)和Fragment(Android 3.0 才引入的),官方文档说ViewPager+Fragment配合使用更好。ViewPager不在android sdk 自带jar包中,来源google 的补充组件android-support-v4.jar,没有的话可以通过eclipse下载和自己下载再添加到相应的工程中,本例用的是android-support-v13.jar,完全兼容android-support-v4.jar,看看android-support-v13.jar的目录结构:

[android-support-v13.jar下载]

         切入正题,ViewPager用法如下:

配置文件:viewpager_layout.xml:

[java]  view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent" >  
  5.       
  6.     <android.support.v4.view.ViewPager  
  7.         android:id="@+id/viewpager"  
  8.         android:layout_width="fill_parent"  
  9.         android:layout_height="wrap_content" />  
  10.   
  11. </RelativeLayout>  


源文件如下ViewPagerActivity.java如下:


[java]  view plain copy
  1. package com.xyz.vvv.ViewPager;  
  2.   
  3. import java.util.ArrayList;  
  4.   
  5. import com.xyz.vvv.R;  
  6.   
  7. import android.app.ActionBar;  
  8. import android.app.ActionBar.LayoutParams;  
  9. import android.app.ActionBar.Tab;  
  10. import android.app.ActionBar.TabListener;  
  11. import android.app.Activity;  
  12. import android.app.Fragment;  
  13. import android.app.FragmentTransaction;  
  14. import android.content.Context;  
  15. import android.os.Bundle;  
  16. import android.support.v13.app.FragmentPagerAdapter;  
  17. import android.support.v4.view.ViewPager;  
  18. import android.support.v4.view.ViewPager.OnPageChangeListener;  
  19. import android.view.LayoutInflater;  
  20. import android.view.View;  
  21.   
  22. public class ViewPagerActivity extends Activity {  
  23.   
  24.     private ViewPager mViewPager;  
  25.     private ViewPagerAdapter mAdapter;  
  26.     private ActionBar mTabBar;  
  27.   
  28.     @Override  
  29.     protected void onCreate(Bundle savedInstanceState) {  
  30.         // TODO Auto-generated method stub  
  31.         super.onCreate(savedInstanceState);  
  32.         setContentView(R.layout.viewpager_layout);  
  33.   
  34.         mViewPager = (ViewPager) findViewById(R.id.viewpager);  
  35.         mAdapter = new ViewPagerAdapter(this, mViewPager);  
  36.         mTabBar = getActionBar();  
  37.   
  38.         mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_qworld),  
  39.                 FirstFragment.classnull);  
  40.         mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_group),  
  41.                 SecondFragment.classnull);  
  42.         mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_friends),  
  43.                 ThreeFragment.classnull);  
  44.         mAdapter.addTab(mTabBar.newTab().setIcon(R.drawable.tab_icon_recent),  
  45.                 FourFragment.classnull);  
  46.   
  47.     }  
  48.   
  49.     private View getCustomView() {  
  50.         return getLayoutInflater().inflate(R.layout.title_panel_layout, null);  
  51.     }  
  52.   
  53.     private static class ViewPagerAdapter extends FragmentPagerAdapter  
  54.             implements TabListener, OnPageChangeListener {  
  55.   
  56.         private Context mContext;  
  57.         private ActionBar mActionBar = null;  
  58.         private ViewPager mViewPager = null;  
  59.         private ArrayList<TabInfo> mTabList = new ArrayList<TabInfo>();  
  60.   
  61.         public ViewPagerAdapter(Activity activity, ViewPager viewPager) {  
  62.             // TODO Auto-generated constructor stub  
  63.             super(activity.getFragmentManager());  
  64.             mContext = activity;  
  65.             mActionBar = activity.getActionBar();  
  66.             /* 
  67.              * mActionBar.setCustomView(getCustomView(), new LayoutParams( 
  68.              * LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT)); 
  69.              */  
  70.             mActionBar.setDisplayOptions(mActionBar.getDisplayOptions()  
  71.                     ^ ActionBar.DISPLAY_SHOW_HOME  
  72.                     ^ ActionBar.DISPLAY_SHOW_TITLE, ActionBar.DISPLAY_SHOW_HOME  
  73.                     | ActionBar.DISPLAY_SHOW_TITLE);  
  74.             mActionBar.setDisplayShowHomeEnabled(false);  
  75.             mActionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);  
  76.             mViewPager = viewPager;  
  77.             mViewPager.setAdapter(this);  
  78.             mViewPager.setOnPageChangeListener(this);  
  79.         }  
  80.   
  81.         /** Override OnPageChangeListener start **/  
  82.         @Override  
  83.         public void onPageScrollStateChanged(int arg0) {  
  84.             // TODO Auto-generated method stub  
  85.   
  86.         }  
  87.   
  88.         @Override  
  89.         public void onPageScrolled(int position, float positionOffset,  
  90.                 int positionOffsetPixels) {  
  91.             // TODO Auto-generated method stub  
  92.   
  93.         }  
  94.   
  95.         @Override  
  96.         public void onPageSelected(int position) {  
  97.             // TODO Auto-generated method stub  
  98.             mActionBar.setSelectedNavigationItem(position);  
  99.         }  
  100.   
  101.         /** Override OnPageChangeListener end **/  
  102.   
  103.         /** Override TabListener start **/  
  104.         @Override  
  105.         public void onTabSelected(Tab tab, FragmentTransaction ft) {  
  106.             // TODO Auto-generated method stub  
  107.             Object tag = tab.getTag();  
  108.             for (int i = 0; i < mTabList.size(); i++) {  
  109.                 if (mTabList.get(i) == tag) {  
  110.                     mViewPager.setCurrentItem(i);  
  111.                 }  
  112.             }  
  113.         }  
  114.   
  115.         @Override  
  116.         public void onTabUnselected(Tab tab, FragmentTransaction ft) {  
  117.             // TODO Auto-generated method stub  
  118.   
  119.         }  
  120.   
  121.         @Override  
  122.         public void onTabReselected(Tab tab, FragmentTransaction ft) {  
  123.             // TODO Auto-generated method stub  
  124.   
  125.         }  
  126.   
  127.         /** Override TabListener end **/  
  128.   
  129.         /** Override FragmentPagerAdapter start **/  
  130.         @Override  
  131.         public Fragment getItem(int position) {  
  132.             // TODO Auto-generated method stub  
  133.             TabInfo tab = mTabList.get(position);  
  134.             if (tab.fragment == null) {  
  135.                 tab.fragment = Fragment.instantiate(mContext,  
  136.                         tab.clazz.getName(), tab.bundle);  
  137.             }  
  138.             return tab.fragment;  
  139.         }  
  140.   
  141.         @Override  
  142.         public int getCount() {  
  143.             // TODO Auto-generated method stub  
  144.             return mTabList.size();  
  145.         }  
  146.   
  147.         /** Override FragmentPagerAdapter end **/  
  148.   
  149.         private View getCustomView() {  
  150.             LayoutInflater inflater = (LayoutInflater) mContext  
  151.                     .getSystemService(Context.LAYOUT_INFLATER_SERVICE);  
  152.             return inflater.inflate(R.layout.title_panel_layout, null);  
  153.         }  
  154.   
  155.         public void addTab(Tab tab, Class<?> clazz, Bundle bundle) {  
  156.             TabInfo tabInfo = new TabInfo(clazz, bundle);  
  157.             tab.setTag(tabInfo);  
  158.             tab.setTabListener(this);  
  159.             mTabList.add(tabInfo);  
  160.             mActionBar.addTab(tab);  
  161.             notifyDataSetChanged();  
  162.         }  
  163.   
  164.         private static final class TabInfo {  
  165.             private final Class<?> clazz;  
  166.             private final Bundle bundle;  
  167.             Fragment fragment;  
  168.   
  169.             TabInfo(Class<?> clazz, Bundle bundle) {  
  170.                 this.clazz = clazz;  
  171.                 this.bundle = bundle;  
  172.             }  
  173.         }  
  174.   
  175.     }  
  176.   
  177. }  

        里面用到的FirstFragment,SecondFragment,ThreeFragment,FourFragment分别继承Fragment,运行效果如下:

        第一个就弄里个TextView,复杂的界面开发者任由发挥了,第二个和第四个都是ListView,第三个ExpandableListView,ListView的使用难点就是写适配器咯,本例是继承BaseAdapter的。ExpandableListView需要一个继承BaseExpandableListAdapter的适配器[不会的请看:ExpandableListView用法]。


2.ViewFlipper

        ViewFilpper控件是系统自带控件之一,主要为在同一个屏幕间的切换及设置动画效果,且可以自动播放,用法如下:

配置文件:viewflipper_layout.xml

[java]  view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     xmlns:xyz="http://schemas.android.com/apk/res/com.xyz.vvv"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent" >  
  6.   
  7.     <ViewFlipper  
  8.         android:id="@+id/viewflipper"  
  9.         android:layout_width="match_parent"  
  10.         android:layout_height="match_parent"  
  11.         android:inAnimation="@anim/slide_in"  
  12.         android:outAnimation="@anim/slide_out"  
  13.         android:flipInterval="2000" >  
  14.   
  15.         <include layout="@layout/viewflipper_one_layout" />  
  16.   
  17.         <include layout="@layout/viewflipper_two_layout" />  
  18.   
  19.         <include layout="@layout/viewflipper_three_layout" />  
  20.   
  21.         <include layout="@layout/viewflipper_four_layout" />  
  22.   
  23.         <include layout="@layout/viewflipper_five_layout" />  
  24.     </ViewFlipper>  
  25.   
  26.     <!--    
  27.     <com.xyz.vvv.PageControlView  
  28.         android:id="@+id/viewflipper_indicator"  
  29.         android:layout_width="fill_parent"  
  30.         android:layout_height="wrap_content"  
  31.         android:layout_marginBottom="25dip"  
  32.         android:gravity="center_horizontal"  
  33.         android:layout_alignParentBottom="true"  
  34.         xyz:cell_width="@dimen/indicator_width"  
  35.         xyz:cell_height="@dimen/indicator_height" />  
  36.     -->  
  37.   
  38. </RelativeLayout>  

        被注释的部分是指示器,那五个layout里都是一个ImageView,本例图片中画有指示器,PageControlView就不需要啦。

       android:autoStart="true" <<==>> mViewFlipper.startFlipping();  //自动播放

       android:flipInterval="2000" <<==>>mViewFlipper.setFilpInterval(2000);  //设置View之间切换的时间间隔

       android:inAnimation="@anim/slide_in", android:outAnimation="@anim/slide_out" 对应方法:mViewFlipper.setInAnimation,

              mViewFlipper.setOutAnimation。

 

源文件:ViewFlipperActivity.java

[java]  view plain copy
  1. package com.xyz.vvv.ViewFlipper;  
  2.   
  3. import com.xyz.vvv.R;  
  4.   
  5. import android.app.Activity;  
  6. import android.os.Bundle;  
  7. import android.view.GestureDetector;  
  8. import android.view.GestureDetector.OnGestureListener;  
  9. import android.view.MotionEvent;  
  10. import android.view.View;  
  11. import android.view.View.OnTouchListener;  
  12. import android.widget.ViewFlipper;  
  13.   
  14. public class ViewFlipperActivity extends Activity implements OnGestureListener,  
  15.         OnTouchListener {  
  16.   
  17.     private ViewFlipper mViewFlipper;  
  18.     private GestureDetector mGestureDetector;  
  19.   
  20.     @Override  
  21.     protected void onCreate(Bundle savedInstanceState) {  
  22.         // TODO Auto-generated method stub  
  23.         super.onCreate(savedInstanceState);  
  24.         setContentView(R.layout.viewflipper_layout);  
  25.   
  26.         mGestureDetector = new GestureDetector(this);  
  27.         mViewFlipper = (ViewFlipper) findViewById(R.id.viewflipper);  
  28.         mViewFlipper.setOnTouchListener(this);  
  29.         mViewFlipper.startFlipping();  
  30.     }  
  31.   
  32.     @Override  
  33.     public boolean onDown(MotionEvent e) {  
  34.         // TODO Auto-generated method stub  
  35.         return false;  
  36.     }  
  37.   
  38.     @Override  
  39.     public void onShowPress(MotionEvent e) {  
  40.         // TODO Auto-generated method stub  
  41.   
  42.     }  
  43.   
  44.     @Override  
  45.     public boolean onSingleTapUp(MotionEvent e) {  
  46.         // TODO Auto-generated method stub  
  47.         return false;  
  48.     }  
  49.   
  50.     @Override  
  51.     public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,  
  52.             float distanceY) {  
  53.         // TODO Auto-generated method stub  
  54.         return false;  
  55.     }  
  56.   
  57.     @Override  
  58.     public void onLongPress(MotionEvent e) {  
  59.         // TODO Auto-generated method stub  
  60.   
  61.     }  
  62.   
  63.     @Override  
  64.     public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,  
  65.             float velocityY) {  
  66.         // TODO Auto-generated method stub  
  67.         if (e2.getX() - e1.getX() > 0) {  
  68.             //mViewFlipper.showPrevious();  
  69.         } else {  
  70.             //mViewFlipper.showNext();  
  71.         }  
  72.         return true;  
  73.     }  
  74.   
  75.     @Override  
  76.     public boolean onTouch(View v, MotionEvent event) {  
  77.         // TODO Auto-generated method stub  
  78.         mGestureDetector.onTouchEvent(event);  
  79.         return true;  
  80.     }  
  81.   
  82. }  

效果图如下:

图片太宽了,还有一张没加进来(图片来自手机QQ)。

         这是ViewFlipper静态加载View,动态加载View请看:ViewFlipper动态加载View

 

3.ViewFlow

        Viewflow 是 Android 平台上一个视图切换的效果库,非标准的得自己下载。ViewFlow 相当于 Android UI 部件提供水平滚动的 ViewGroup,使用 Adapter 进行条目绑定。这个拿来主义 ^-^

           按图说话吧:  带圆点的指示器。

配置文件:circle_viewflow_layout.xml

[java]  view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     xmlns:xyz="http://schemas.android.com/apk/res/com.xyz.vvv"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     android:orientation="vertical" >  
  7.   
  8.     <org.taptwo.android.widget.ViewFlow  
  9.         android:id="@+id/viewflow"  
  10.         android:layout_width="fill_parent"  
  11.         android:layout_height="fill_parent"  
  12.         xyz:sidebuffer="3" >  
  13.     </org.taptwo.android.widget.ViewFlow>  
  14.   
  15.     <org.taptwo.android.widget.CircleFlowIndicator  
  16.         android:id="@+id/viewflowindic"  
  17.         android:layout_width="wrap_content"  
  18.         android:layout_height="wrap_content"  
  19.         android:layout_gravity="bottom|center_horizontal"  
  20.         android:padding="10dip"  
  21.         android:layout_marginBottom="10dip"  
  22.         xyz:fadeOut="1000"  
  23.         xyz:inactiveType="stroke" />  
  24.   
  25. </FrameLayout>  

源文件:CircleViewFlowActivity.java

[java]  view plain copy
  1. package com.xyz.vvv.ViewFlow;  
  2.   
  3. import org.taptwo.android.widget.CircleFlowIndicator;  
  4. import org.taptwo.android.widget.ViewFlow;  
  5.   
  6. import com.xyz.vvv.R;  
  7.   
  8. import android.app.Activity;  
  9. import android.content.Context;  
  10. import android.content.res.Configuration;  
  11. import android.os.Bundle;  
  12. import android.view.LayoutInflater;  
  13. import android.view.View;  
  14. import android.view.ViewGroup;  
  15. import android.widget.BaseAdapter;  
  16. import android.widget.ImageView;  
  17.   
  18. public class CircleViewFlowActivity extends Activity {  
  19.   
  20.     private ViewFlow mViewFlow;  
  21.     private CircleFlowIndicator mIndicator = null;  
  22.   
  23.     /** Called when the activity is first created. */  
  24.     @Override  
  25.     public void onCreate(Bundle savedInstanceState) {  
  26.         super.onCreate(savedInstanceState);  
  27.         setTitle(R.string.circle_title);  
  28.         setContentView(R.layout.circle_viewflow_layout);  
  29.   
  30.         mViewFlow = (ViewFlow) findViewById(R.id.viewflow);  
  31.         mViewFlow.setAdapter(new ViewFlowAdapter(this), 0);  
  32.         mIndicator = (CircleFlowIndicator) findViewById(R.id.viewflowindic);  
  33.         mViewFlow.setFlowIndicator(mIndicator);  
  34.     }  
  35.   
  36.     @Override  
  37.     public void onConfigurationChanged(Configuration newConfig) {  
  38.         super.onConfigurationChanged(newConfig);  
  39.         mViewFlow.onConfigurationChanged(newConfig);  
  40.     }  
  41.   
  42.     private class ViewFlowAdapter extends BaseAdapter {  
  43.   
  44.         private Context mContext;  
  45.         private LayoutInflater mInflater = null;  
  46.         private final int[] mImageIds = { R.drawable.cupcake, R.drawable.donut,  
  47.                 R.drawable.eclair, R.drawable.froyo, R.drawable.gingerbread,  
  48.                 R.drawable.honeycomb, R.drawable.icecream };  
  49.   
  50.         public ViewFlowAdapter(Context ctx) {  
  51.             mContext = ctx;  
  52.             mInflater = (LayoutInflater) mContext  
  53.                     .getSystemService(Context.LAYOUT_INFLATER_SERVICE);  
  54.         }  
  55.   
  56.         @Override  
  57.         public int getCount() {  
  58.             // TODO Auto-generated method stub  
  59.             return mImageIds.length;  
  60.         }  
  61.   
  62.         @Override  
  63.         public Integer getItem(int position) {  
  64.             // TODO Auto-generated method stub  
  65.             return mImageIds[position];  
  66.         }  
  67.   
  68.         @Override  
  69.         public long getItemId(int position) {  
  70.             // TODO Auto-generated method stub  
  71.             return position;  
  72.         }  
  73.   
  74.         @Override  
  75.         public View getView(int position, View convertView, ViewGroup parent) {  
  76.             // TODO Auto-generated method stub  
  77.             if (convertView == null) {  
  78.                 convertView = mInflater.inflate(R.layout.circle_viewflow_item_layout,  
  79.                         null);  
  80.             }  
  81.             ((ImageView) convertView.findViewById(R.id.img_view))  
  82.                     .setImageResource(getItem(position));  
  83.             return convertView;  
  84.         }  
  85.   
  86.     }  
  87. }  

        ViewFlow还有其他几个例子,个人觉得用的不多,就不贴啦,感兴趣的可以下载下来研究下。

      源码下载:http://download.csdn.net/detail/zhouyuanjing/4886174

        ~~完~~

这篇关于android ViewPager,ViewFlipper,ViewFlow实现左右滑动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1071062

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现