我们向上一个系统中增加一些功能,在成功登陆后,跳转到一个主操作界面,此界面为所有功能的入口,用一个GridView来实现

GridView的经典实现方法流程:布局文件中声明GridView ---> 编写一个ImageAdapter继承BaseAdapter并主要复写getView()方法 ---> 给GridView添加此adapter

布局文件很简单:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent" >        <GridView         android:id="@+id/gridView"        android:layout_width="match_parent"        android:layout_height="match_parent"        android:columnWidth="90dp"        android:numColumns="auto_fit"        android:verticalSpacing="10dp"        android:horizontalSpacing="10dp"        android:stretchMode="columnWidth"        android:gravity="center"        />        </LinearLayout>

主Activity同样很简单,放在com.moka.activities中:

public class MainMenuActivity extends Activity {        private GridView gridView = null;        @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.main_menu);                gridView = (GridView) findViewById(R.id.gridView);        gridView.setAdapter(new ImageAdapter(this));    }    }

ImageAdapter的编写稍微复杂,因为在这里我们把所用监听事件均放在这里处理,在这里我们先添加的是点菜功能,所以姑且把别的监听事件做简单处理

它放在com.moka.provider中:

public class ImageAdapter extends BaseAdapter {        private Context context = null;        // 所需的图片资源    private Integer[] functionImgs = { R.drawable.diancai, R.drawable.bingtai, R.drawable.zhuantai,            R.drawable.chatai, R.drawable.gengxin, R.drawable.shezhi,            R.drawable.zhuxiao, R.drawable.jietai };        public ImageAdapter(Context context) {        this.context = context;    }        @Override    public int getCount() {        return functionImgs.length;    }    @Override    public Object getItem(int position) {        return null;    }    @Override    public long getItemId(int position) {        return position;    }    @Override    public View getView(int position, View convertView, ViewGroup parent) {        // 准备向GridView中填充的ImageView图片与其一些参数        ImageView imageView = null;        if (convertView == null) {            imageView = new ImageView(context);            imageView.setLayoutParams(new GridView.LayoutParams(85, 85));            imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);            imageView.setPadding(8, 8, 8, 8);        } else {            imageView = (ImageView) convertView;        }        // 设置图片源        imageView.setImageResource(this.functionImgs[position]);                // 设置监听事件        switch (position) {        case 0:            imageView.setOnClickListener(new OrderListener());            break;        case 1:            imageView.setOnClickListener(new UnionTableListener());            break;        case 2:            imageView.setOnClickListener(new ChangeTableListener());            break;        case 3:            imageView.setOnClickListener(new CheckTableListener());            break;        case 4:            imageView.setOnClickListener(new UpdateListener());            break;        case 5:            imageView.setOnClickListener(new SetupListener());            break;        case 6:            imageView.setOnClickListener(new ExitListener());            break;        case 7:            imageView.setOnClickListener(new PayListener());            break;        }                return imageView;    }        private class OrderListener implements OnClickListener {        @Override        public void onClick(View v) {            Intent intent = new Intent(context, OrderActivity.class);            intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);            context.startActivity(intent);        }            }    private class UnionTableListener implements OnClickListener {                @Override        public void onClick(View v) {            Toast.makeText(context, "并台!", Toast.LENGTH_SHORT).show();        }            }    private class ChangeTableListener implements OnClickListener {                @Override        public void onClick(View v) {            Toast.makeText(context, "转台!", Toast.LENGTH_SHORT).show();        }            }    private class CheckTableListener implements OnClickListener {                @Override        public void onClick(View v) {            Toast.makeText(context, "查台!", Toast.LENGTH_SHORT).show();        }            }    private class UpdateListener implements OnClickListener {                @Override        public void onClick(View v) {            Toast.makeText(context, "更新!", Toast.LENGTH_SHORT).show();        }            }    private class SetupListener implements OnClickListener {                @Override        public void onClick(View v) {            Toast.makeText(context, "设置!", Toast.LENGTH_SHORT).show();        }            }    private class ExitListener implements OnClickListener {                @Override        public void onClick(View v) {            Toast.makeText(context, "注销!", Toast.LENGTH_SHORT).show();        }            }    private class PayListener implements OnClickListener {                @Override        public void onClick(View v) {            Toast.makeText(context, "结台!", Toast.LENGTH_SHORT).show();        }            }}

关于点菜的OrderActivity及其服务器端有一定的难度,我们稍后再讨论,先看一下主操作界面效果:

更多相关文章

  1. Android多点触摸与手势
  2. 多媒体录制音频/视频之——MediaRecorder
  3. Android(安卓)屏幕截图 代码
  4. Android设备上的简易备忘录(Memo) 具有闹钟功能
  5. Android(安卓)Studio引用另一个模块module的方法
  6. Android:属性scaleType与图片的显示
  7. Android(安卓)RecyclerView嵌套的滑动冲突问题
  8. Android自定义控件系列九:从源码看Android触摸事件分发机制
  9. Android8.0 存储系统

随机推荐

  1. 开源一个友盟 for android 操作的封装包
  2. android SeekBar自定义样式滑动条的使用
  3. Android之短信接收
  4. Android(安卓)拨打电话 对方接听时震动功
  5. android 4.2 源码在64位Ubuntu编译
  6. android布局中容易混淆的几个属性
  7. Android学习一:Hello World
  8. 《Android第一行代码》first reading 十
  9. android aidl iBinder理解
  10. [置顶] Android之ContextMenu的使用方法