如何用安卓开发出复杂表格(类似Excel统计表)?

 我来答
汐日南莘
2015-06-04 · TA获得超过1.4万个赞
知道大有可为答主
回答量:1.6万
采纳率:45%
帮助的人:7756万
展开全部

Android实现Excel表格

具体的用法: 写好xml的布局文件:分为头部标题和lsitView两个部分。 头部标题永远排在第一列,其中第一个会滑动所以在布局的时候就不要放在
* com.excel.tool.MyHScrollView里面(MyHScrollView重写的HorizontalScrollView)。
* 其它没有什么就是对其滑动处理的把握。

* item里面的数据以及布局,按照正确的布局方式和逻辑处理。

* 它的用法其实你当做简单的listView那样操作就可以了。

* 排序没有完善,其实都是同一个方法,有待合并。


public class MainActivity extends Activity {
        Context context;
        private ListView listView;
        private LinearLayout toplayout;
        private MyAdapter myAdapter;
        public List<DataModel> BaseData;
        private HorizontalScrollView horizontalScrollView;
        /**
         * 
         * isTouchItem值的改变在
         * 
         * com.excel.tool.MyHScrollView中去判断--解决ListView很容易触发点击事件
         * 
         * 里面处理 控制表格滑动很容易触发的点击事件问题
         */
        public static boolean isTouchItem = false;
        /***
         * 
         * 排序的监听
         */
        private LinearLayout sort_0;
        private boolean ischeck;

        private ImageView sort_triangle;

        @Override
        protected void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.activity_main);
                context = MainActivity.this;
                viewInit();
                dataInit();
        }

        /***
         * 
         * view的初始化
         * 
         */
        public void viewInit() {

                toplayout = (LinearLayout) findViewById(R.id.toplayout);
                toplayout.setOnTouchListener(onTouchListener);
                horizontalScrollView = (HorizontalScrollView) toplayout
                                .findViewById(R.id.horizontalScrollView_excel);

                listView = (ListView) findViewById(R.id.listView);
                listView.setOnItemClickListener(onItemClickListener);
                listView.setOnTouchListener(onTouchListener);

                sort_0 = (LinearLayout) findViewById(R.id.sort_0);
                sort_0.setOnClickListener(onClickListener);
                sort_triangle = (ImageView) findViewById(R.id.waterlevel_triangle);

        }

        /***
         * 
         * 数据的初始化
         * 
         */
        public void dataInit() {
                if (BaseData == null)
                        BaseData = new ArrayList<DataModel>();

                myAdapter = new MyAdapter(context, toplayout);

                for (int i = 0; i < Data.subject.length; i++) {
                        DataModel model = new DataModel();
                        model.setSubject(Data.subject[i]);
                        model.setChinese(Data.Chinese[i]);
                        model.setMath(Data.Math[i]);
                        model.setEnglish(Data.English[i]);
                        model.setPhysics(Data.Physics[i]);
                        model.setChemistry(Data.Chemistry[i]);
                        model.setBiology(Data.Biology[i]);
                        model.setPE(Data.PE[i]);
                        BaseData.add(model);
                }
                myAdapter.setHostBaseData(BaseData);
                listView.setAdapter(myAdapter);

        }

        private OnClickListener onClickListener = new OnClickListener() {
                @Override
                public void onClick(View v) {
                        switch (v.getId()) {
                        case R.id.sort_0:
                                if (ischeck == false) {
                                        // 对数据进行排序--传入数据,2表示递减排序, 1表示递减
                                        BaseData = Sort.sortchukuData(BaseData, 2);
                                        myAdapter.setHostBaseData(BaseData);
                                        ischeck = true;
                                        sort_triangle
                                                        .setBackgroundResource(R.drawable.triangle_down);
                                } else {
                                        BaseData = Sort.sortchukuData(BaseData, 1);
                                        myAdapter.setHostBaseData(BaseData);
                                        ischeck = false;
                                        sort_triangle.setBackgroundResource(R.drawable.triangle_up);
                                }
                                break;

                        }

                }

        };

        private OnItemClickListener onItemClickListener = new OnItemClickListener() {
                @Override
                public void onItemClick(AdapterView<?> arg0, View arg1, int position,
                                long arg3) {
                        if (isTouchItem == false)
                                return;
                        CustomerToast.showToast(context, "你点击的是:" + position + "这个下标");

                }

        };

        private OnTouchListener onTouchListener = new OnTouchListener() {

                @Override
                public boolean onTouch(View v, MotionEvent event) {
                        switch (v.getId()) {
                        case R.id.toplayout:
                                horizontalScrollView.onTouchEvent(event);
                                return false;
                        case R.id.listView:
                                horizontalScrollView.onTouchEvent(event);
                                return false;

                        }
                        return false;
                }

        };

}

效果图片:

百度网友b7df494
2013-03-29 · TA获得超过313个赞
知道小有建树答主
回答量:365
采纳率:0%
帮助的人:152万
展开全部
Documents To Go

由DataViz 公司开发的一款不错的智能手机办公应用软件。你可以随时随地地查看并编辑Word,Excel和 PowerPoint文件,还可以查看PDF文件,而不用再担心是怎样接受文件 - 无论是否通过外部存储卡,蓝牙,红外线,MMS或电子邮件。
追问
我不是要下载一个应用软件,而是要代码实现这样一个表格功能,其中在表格中填写自己需要的业务数据!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式