Android 类似时间轴的实现

想要实现图片中的的时间轴的效果,设定了三种颜色,但是出来的只有一个黑色,还不是设定好的,而且长度很长的话不能滚动,下面上代码:

布局文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <LinearLayout
        android:id="@+id/trjectory_today_rl1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">
    </LinearLayout>
</LinearLayout>

类文件,时间段是从服务器获取的,多少和大小都是不确定的
主要代码:

private Handler mHandler = new Handler() {
                @Override
                public void handleMessage(Message msg) {
                        switch (msg.what) {
                        case 0:
                                if (trajectory2 != null) {
                                        if (trajectory2.getResponseCode().equals("200")) {
                                                progressDialog.dismiss();
                                                if (trajectory2.getSegmentNum() != 0) {
                                                        thefirsttime = trajectory2.getList().get(0)
                                                                        .get("BeginTime");// 第一个时间段的开始时间,用作参照物
                                                        Y=new int[trajectory2.getSegmentNum()];
                                                        X=new int[trajectory2.getSegmentNum()];
                                                        high=new int[trajectory2.getSegmentNum()];
                                                        color=new int[trajectory2.getSegmentNum()];

                                                        for (int i = 0; i < trajectory2.getList().size(); i++) {
                                                                name = trajectory2.getList().get(i).get("Name");
                                                                begintime = trajectory2.getList().get(i)
                                                                                .get("BeginTime");
                                                                int begin = TimeToInt(begintime);//将阶段开始时间换算为分钟,计算坐标
                                                                endtime = trajectory2.getList().get(i)
                                                                                .get("EndTime");
                                                                int end = TimeToInt(endtime);
                                                                high = end - begin;// 矩形的高度
                                                                Y = begin - TimeToInt(thefirsttime);// 获得矩形的开始的Y轴坐标,最初是0

                                                                if (name.equals("觉醒")) {
                                                                        color = R.color.red;
                                                                        X = width / 2;// 矩形的轴心的坐标
                                                                } else if (name.equals("浅睡")) {
                                                                        color = R.color.lightblue;
                                                                        X = width / 2;

//                                                                        r1.addView(rectview);
                                                                } else if (name.equals("深度睡眠")) {
                                                                        color = R.color.green;
                                                                        X = width / 2 + 20;
                                                                } else {
                                                                        color = R.color.lightgray;
                                                                        X = width / 2;
                                                                }
                                                        }
                                                        rectview=new RectView(getActivity(),X,Y,high,color);
                                                        r1.addView(rectview);

                                                } else {
                                                        progressDialog.dismiss();
                                                        showDialog("提示", "今天没有睡眠信息...");
                                                }

                                        } else {
                                                progressDialog.dismiss();
                                                showDialog("提示", trajectory2.getResponseDesc());
                                        }

                                } else {
                                        progressDialog.dismiss();
                                        showDialog("提示", "获取数据失败...");
                                }
                                break;
                        }
                }        };

下面上画图的类:

热搜: 二维码 定时器 手电筒 滑块 斗地主 书架 定位 买手机 聊天 游戏开发 游戏 股票查询 机顶盒 通话记录 二维码扫描 振动器 listview fragment 音乐播放器 播放器
eoe 移动开发者论坛»社区 › Android开发交流 › Android开发问答 › 类似时间轴的实现
12 / 2 页下一页
返回列表 发新帖回复
查看: 988|回复: 17

打印 上一主题 下一主题
收起左侧
[Android界面] 类似时间轴的实现
[复制链接]

yalongy58

4
主题    

113
帖子    

511
e币

    发消息

电梯直达 跳转到指定楼层
楼主
发表于 2013-12-29 21:37:33 | 只看该作者 |只看大图 回帖奖励
0基础的你+1张学习路径图+3个月粮饷+9阶段系统学习=Android开发大拿
10e币
想要实现图片中的的世间轴的效果,设定了三种颜色,但是出来的只有一个黑色,还不是设定好的,而且长度很长的话不能滚动,下面上代码:布局文件:
[mw_shl_code=java,true]<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <LinearLayout
        android:id="@+id/trjectory_today_rl1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">
    </LinearLayout>
</LinearLayout>[/mw_shl_code]

类文件,时间段是从服务器获取的,多少和大小都是不确定的
主要代码:
[mw_shl_code=java,true]private Handler mHandler = new Handler() {
                @Override
                public void handleMessage(Message msg) {
                        switch (msg.what) {
                        case 0:
                                if (trajectory2 != null) {
                                        if (trajectory2.getResponseCode().equals("200")) {
                                                progressDialog.dismiss();
                                                if (trajectory2.getSegmentNum() != 0) {
                                                        thefirsttime = trajectory2.getList().get(0)
                                                                        .get("BeginTime");// 第一个时间段的开始时间,用作参照物
                                                        Y=new int[trajectory2.getSegmentNum()];
                                                        X=new int[trajectory2.getSegmentNum()];
                                                        high=new int[trajectory2.getSegmentNum()];
                                                        color=new int[trajectory2.getSegmentNum()];

                                                        for (int i = 0; i < trajectory2.getList().size(); i++) {
                                                                name = trajectory2.getList().get(i).get("Name");
                                                                begintime = trajectory2.getList().get(i)
                                                                                .get("BeginTime");
                                                                int begin = TimeToInt(begintime);//将阶段开始时间换算为分钟,计算坐标
                                                                endtime = trajectory2.getList().get(i)
                                                                                .get("EndTime");
                                                                int end = TimeToInt(endtime);
                                                                high = end - begin;// 矩形的高度
                                                                Y = begin - TimeToInt(thefirsttime);// 获得矩形的开始的Y轴坐标,最初是0

                                                                if (name.equals("觉醒")) {
                                                                        color = R.color.red;
                                                                        X = width / 2;// 矩形的轴心的坐标
                                                                } else if (name.equals("浅睡")) {
                                                                        color = R.color.lightblue;
                                                                        X = width / 2;

//                                                                        r1.addView(rectview);
                                                                } else if (name.equals("深度睡眠")) {
                                                                        color = R.color.green;
                                                                        X = width / 2 + 20;
                                                                } else {
                                                                        color = R.color.lightgray;
                                                                        X = width / 2;
                                                                }
                                                        }
                                                        rectview=new RectView(getActivity(),X,Y,high,color);
                                                        r1.addView(rectview);

                                                } else {
                                                        progressDialog.dismiss();
                                                        showDialog("提示", "今天没有睡眠信息...");
                                                }

                                        } else {
                                                progressDialog.dismiss();
                                                showDialog("提示", trajectory2.getResponseDesc());
                                        }

                                } else {
                                        progressDialog.dismiss();
                                        showDialog("提示", "获取数据失败...");
                                }
                                break;
                        }
                }

        };
[/mw_shl_code]

下面上画图的类:
[mw_shl_code=java,true]package com.ban.chart;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.View;

public class RectView extends View {
        private int[] width;//矩形的轴心的坐标
        private int[] height;//矩形的高度
        private int[] top;//矩形的顶部坐标
        private int[] bottom;//矩形底部坐标

        private Chart chart;
        private Paint paint;
        private int[] color;

        public RectView(Context context, AttributeSet attrs) {
                super(context, attrs);
                // TODO Auto-generated constructor stub
        }

        public RectView(Context context) {
                super(context);
                // TODO Auto-generated constructor stub
        }

        public RectView(Context context, int[] X,int[] Y,int[] high,int[] color) {
                super(context);
                this.width=X;//矩形轴心坐标
                this.height=high;//矩形高度
                this.top=Y;//矩形顶部坐标
                this.color=color;
                bottom=new int[height.length];
//                bottom=top+height;//矩形底部坐标
                paint = new Paint();
                paint.setAntiAlias(true);
        }
        // 画柱状图
                public void drawChart(Canvas canvas){
                        for(int i=0;i<height.length;i++){
                                bottom=(top+50)+height*10;
                                paint.setColor(color);
                                canvas.drawRect(width-5, top+50, width+5, bottom, paint) ;

                        }

//                        canvas.drawRect(width-5, top, width+5, bottom, paint) ;
                }
                @Override
                public void onDraw(Canvas canvas){
                        canvas.drawColor(Color.WHITE);
                        drawChart(canvas);
                        invalidate();
                }
}

图片:

时间: 2024-10-05 03:10:36

Android 类似时间轴的实现的相关文章

android 简易时间轴(实质是ListView)

ListView的应用 1.在很多时候是要用到时间轴的,有些处理的时间轴比较复杂,这里就给出一个比较简单的时间轴,其实就是ListView里面的Item的设计. 直接上代码: ListView,item的xml文件-->time_item.xml 1 <?xml version="1.0" encoding="utf-8"?> 2 <RelativeLayout xmlns:android="http://schemas.andro

Android实现时间轴

昨天群里有讨论时间轴的项目,没有接触过,以为很吊,研究之后才知道表面都是忽悠人的,使用listview就能实现了,也没有什么新鲜的东西 废话少说,直接上图 图片和文字都可以私人订制 没什么好说的,直接上代码吧!相信你能看懂 1.时间轴item的布局文件 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.c

对话框以及延伸的时间轴展示

第一个.简单的实现页面的对话框的样式 css代码如下: <style> *{ padding:0; margin:0; } .receiveMessage{ border-radius:4px; background:#fffdfb; padding:50px 15px; width:950px; margin:0 auto; } .receiveMessage>ul{ width:100%; position:relative; } .receiveMessage>ul:befo

Android 时间轴

效果图: 数据是随便填的,显得有点乱,但是不影响效果.实现方面主要是用ListView来实现,主要是根据ListView的item位置与上一条数据进行比较,来控制时间的显示隐藏效果.思路很简单,下面看代码实现: 首先是页面的整体布局,很简单,就一个ListView: res/layout/activity_main.xml: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:and

android项目之时间轴(转载)

转载自:http://blog.csdn.net/caiwenfeng_for_23/article/details/38279317 最近开发的app中要用到时间轴这东西,需要实现的效果如下: 想想这个东西应该可以用listview实现吧.然后最近就模拟着去写了: 首先写  listview的item的布局: listview_item.xml <?xml version="1.0" encoding="utf-8"?> <RelativeLay

Android自定义View实现垂直时间轴布局

时间轴 时间轴,顾名思义就是将发生的事件按照时间顺序罗列起来,给用户带来一种更加直观的体验.京东和淘宝的物流顺序就是一个时间轴,想必大家都不陌生,如下图: 分析 实现这个最常用的一个方法就是用ListView,我这里用继承LinearLayout的方式来实现.首先定义了一些自定义属性: attrs.xml <?xml version="1.0" encoding="utf-8"?> <resources> <declare-stylea

Android时间轴效果,直接使用在你的项目中

近期开发app搞到历史查询,受腾讯qq的启示,搞一个具有时间轴效果的ui,看上去还能够,然后立即想到分享给小伙伴,,大家一起来看看,先上效果图吧 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" > 接下来就是代码了,axtivity的布局代码.非常easy.就是一个listview <?xml v

可缩放时间轴和录像片段选择器的实现

最近的工作是做了两个自定义控件:①可以缩放的时间轴②吸附在在时间轴上有两个滑动按钮的录像片段选择器 真机测试效果如下面的gif动画所示: -------–最近更新 华丽丽的分割线---------由于很多小伙伴私信我要源码,所以最近整理了一下,放在github上了,地址:https://github.com/ljfxyj2008/ScalableTimebar-------–End of 最近更新--------- 在此记录一下设计原理和踩过的坑. 时间轴 时间轴分为两部分轴,刻度轴和录像片段轴

时光轴 时间轴 效果

要实现类似QQ空间那样时光轴 时间轴效果 如图 ==================== 分析:左边 ul的border-left实现,这样会出现底部的 余出的线条,不美观, 所以考虑li的border-left实现. li的padding-bottom撑开上下间距 h4标题的:before实现圆圈,定位到左边. 圆圈的实现使用绝对定位实现,注意下UL和LI实现方式下的,圆圈定位位置. =========Ul实现边框======= .money-process .process-list { w