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

近期开发app搞到历史查询,受腾讯qq的启示,搞一个具有时间轴效果的ui,看上去还能够,然后立即想到分享给小伙伴,,大家一起来看看,先上效果图吧

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" >

接下来就是代码了,axtivity的布局代码。非常easy。就是一个listview

<?xml version="1.0" encoding="utf-8"?

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

	<ListView
	    android:id="@+id/listview"
	    android:layout_width="fill_parent"
	    android:layout_height="wrap_content"/>

</LinearLayout>

以下就是activity.java这个了

package com.agbc.activity;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

import java.util.Map;

import com.agbc.adapter.TimelineAdapter;
import com.agbc.listview.XListView;
import com.example.agbc.R;
import com.lidroid.xutils.ViewUtils;
import com.lidroid.xutils.view.annotation.ViewInject;

import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.widget.ListView;
/**
 * 历史时间轴
 * @author twj
 *
 */
public class HistoryTaskActivity extends FragmentActivity{
	private XListView listView;
	List<String> data ;
	private TimelineAdapter timelineAdapter;
	@Override
	protected void onCreate(Bundle arg0) {
		super.onCreate(arg0);
		setContentView(R.layout.activity_timeline);
		findViewById();
		listView.setDividerHeight(0);
		timelineAdapter=new TimelineAdapter(getDate(), this);
		listView.setAdapter(timelineAdapter);
	}

	private List<Map<String, Object>> getDate() {
		List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();

		Map<String, Object> map = new HashMap<String, Object>();
		map.put("year", "2014");
		map.put("month", "03/15");
		map.put("title", "这是第1行測试数据");
		list.add(map);

		map = new HashMap<String, Object>();
		map.put("year", "2014");
		map.put("month", "12/1");
		map.put("title", "这是第2行測试数据");
		list.add(map);

		map = new HashMap<String, Object>();
		map.put("year", "2013");
		map.put("month", "11/15");
		map.put("title", "这是第3行測试数据");
		list.add(map);

		map = new HashMap<String, Object>();
		map.put("year", "1998");
		map.put("month", "01/1");
		map.put("title", "这是第4行測试数据");
		list.add(map);
		return list;
	}

	private void findViewById() {
		listView=(XListView) findViewById(R.id.listview);	

	}

}

接下来就是适配器了。适配器事实上也简单

package com.example.timelinetext.test;

import java.util.List;
import java.util.Map;

import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

public class TimelineAdapter extends BaseAdapter {

	private Context context;
	private List<Map<String, Object>> list;
	private LayoutInflater inflater;

	public TimelineAdapter(Context context, List<Map<String, Object>> list) {
		super();
		this.context = context;
		this.list = list;
	}

	@Override
	public int getCount() {

		return list.size();
	}

	@Override
	public Object getItem(int position) {
		return position;
	}

	@Override
	public long getItemId(int position) {
		return position;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		ViewHolder viewHolder = null;
			inflater = LayoutInflater.from(parent.getContext());
			convertView = inflater.inflate(R.layout.adapter_timeline, null);
			viewHolder = new ViewHolder();
			viewHolder.year = (TextView) convertView.findViewById(R.id.year);
			viewHolder.month = (TextView) convertView.findViewById(R.id.month);
			viewHolder.title = (TextView) convertView.findViewById(R.id.title);

		String yearStr = list.get(position).get("year").toString();
		String monthStr = list.get(position).get("month").toString();
		String titleStr = list.get(position).get("title").toString();

		viewHolder.year.setText( yearStr);
		viewHolder.month.setText(monthStr);
		viewHolder.title.setText(titleStr);

		return convertView;
	}

	static class ViewHolder {
		public TextView year;
		public TextView month;
		public TextView title;
	}
}

最后就是适配器布局代码了,事实上效果就是在这里提现出来的

<?

xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#ffffff"
    android:orientation="vertical"
    android:paddingRight="20dp" >

    <RelativeLayout
        android:id="@+id/layout_1"
        android:layout_width="60dp"
        android:layout_height="25dp"
        android:layout_marginLeft="43dp"
        android:background="@android:color/black"
        android:gravity="center" >

        <TextView
            android:id="@+id/month"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="測试数据"
            android:textColor="#FFFFFF"
            android:textSize="12sp" />
    </RelativeLayout>

    <View
        android:id="@+id/view_0"
        android:layout_width="1dp"
        android:layout_height="25dp"
        android:layout_below="@+id/layout_1"
        android:layout_marginLeft="71dp"
        android:background="#A6A6A6" />

    <RelativeLayout
        android:id="@+id/layout_2"
        android:layout_width="60dp"
        android:layout_height="25dp"
        android:layout_below="@+id/view_0"
        android:layout_marginLeft="43dp"
        android:background="@android:color/black"
        android:gravity="center" >

        <TextView
            android:id="@+id/year"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="測试数据"
            android:textColor="#FFFFFF"
            android:textSize="12sp" />
    </RelativeLayout>

    <View
        android:id="@+id/view_1"
        android:layout_width="1dp"
        android:layout_height="25dp"
        android:layout_below="@+id/layout_2"
        android:layout_marginLeft="71dp"
        android:background="#A6A6A6" />

    <TextView
        android:id="@+id/show_time"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/view_1"
        android:layout_marginLeft="30dp"
        android:text="測试数据"
        android:textSize="12dp" />

    <ImageView
        android:id="@+id/image"
        android:layout_width="15dp"
        android:layout_height="15dp"
        android:layout_below="@+id/view_1"
        android:layout_marginLeft="65dp"
        android:src="@drawable/timeline_green" />

    <View
        android:id="@+id/view_2"
        android:layout_width="1dp"
        android:layout_height="100dp"
        android:layout_below="@+id/image"
        android:layout_marginLeft="71dp"
        android:background="#A6A6A6" />

    <RelativeLayout
        android:id="@+id/relative"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_below="@+id/image"
        android:layout_marginTop="-20dp"
        android:layout_toRightOf="@+id/image"
        android:background="@drawable/timeline_content"
        android:padding="10dp" >

        <ImageView
            android:id="@+id/image_1"
            android:layout_width="60dp"
            android:layout_height="60dp"
            android:layout_alignParentLeft="true"
            android:layout_centerVertical="true"
            android:layout_marginLeft="5dp"
            android:src="@drawable/bg_green_circle_smic" />

        <TextView
            android:id="@+id/title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@+id/image_1"
            android:ellipsize="end"
            android:singleLine="true"
            android:maxEms="7"
            android:paddingLeft="5dp"
            android:text="測试数据"
            android:textSize="12sp" />

        <ImageView
            android:id="@+id/personal_circle"
            android:layout_width="15dp"
            android:layout_height="15dp"
            android:layout_toRightOf="@+id/title"
            android:src="@drawable/ic_launcher" />

        <TextView
            android:id="@+id/text_2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@+id/image_1"
            android:paddingLeft="5dp"
            android:paddingTop="20dp"
            android:text="測试数据"
            android:textSize="12sp" />

        <TextView
            android:id="@+id/text_3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@+id/text_2"
            android:ellipsize="end"
            android:singleLine="true"
            android:paddingTop="20dp"
            android:text="測试数据"
            android:textSize="12sp" />

        <TextView
            android:id="@+id/text_4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@+id/image_1"
            android:paddingLeft="5dp"
            android:paddingTop="40dp"
            android:text="測试数据"
            android:textSize="12sp" />

        <TextView
            android:id="@+id/text_5"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@+id/text_4"
            android:ellipsize="end"
            android:singleLine="true"
            android:paddingTop="40dp"
            android:text="測试数据"
            android:textSize="12sp" />

        <TextView
            android:id="@+id/text_6"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@+id/image_1"
            android:paddingLeft="5dp"
            android:paddingTop="60dp"
            android:text="測试数据"
            android:textSize="12sp" />

        <TextView
            android:id="@+id/text_7"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignRight="@+id/text_3"
            android:layout_alignTop="@+id/title"
            android:layout_toRightOf="@+id/text_6"
            android:ellipsize="end"
            android:singleLine="true"
            android:paddingTop="60dp"
            android:text="測试数据"
            android:textSize="12sp" />
    </RelativeLayout>

</RelativeLayout>

好吧!时间轴事实上原理非常easy的。就是几个控件。调调位置而已,只是在实际开发中可能要对时间轴上面的控件进行操作,这就是关于事件分发的机制了,哎,事实上都是写烂的代码了。好了。这个天我要去研究tcp/ip通信了。

原文地址:https://www.cnblogs.com/llguanli/p/8470522.html

时间: 2024-10-26 19:12:57

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

使用ExpandableListView时间轴效果达到

不废话,首先在地图上,查看结果 这是用ExpandableListView来实现时间轴效果,原理比較简单,以月份为第一级,以天为第二级来实现的. package com.hj.main; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.content.Context; import android.os.Bundle; import android.uti

使用ExpandableListView实现时间轴效果

不废话,先上图,看看效果 这是用ExpandableListView来实现时间轴效果,原理比较简单,以月份为第一级,以天为第二级来实现的. package com.hj.main; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.content.Context; import android.os.Bundle; import android.util.L

JS时间轴效果(类似于qq空间时间轴效果)

2013-11-04 23:51 by 空智, 4041 阅读, 15 评论, 收藏, 编辑 在上一家公司写了一个时间轴效果,今天整理了下,感觉有必要写一篇博客出来 给大家分享分享 当然代码还有很多不足的地方,希望大家多指点指点下,此效果类似于QQ空间或者人人网空间时间轴效果,当时也是为了需求 研究了下qq空间逻辑(当然JS代码压缩了肯定看不到的),只是当时研究了下他们HTML结构和css结构,所以仿照他们那种逻辑自己也写了一个出来.先来看看是个什么样的吧!如下图所示: 需求分析:左侧是一个时间

时光轴 时间轴 效果

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

jQuery鼠标滑过横向时间轴效果

jQuery鼠标滑过横向时间轴效果---效果图: jQuery鼠标滑过横向时间轴效果---全部代码: <!DOCTYPE html> <html> <head> <title></title> <link rel="stylesheet" type="text/css" href="css/style.css"> </head> <body> <

Android 时间轴

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

CSS3实现时间轴效果

最近打开电脑就能看到极客学院什么新用户vip免费一个月,就进去看看咯,这里就不说它的课程怎么滴了,里面实战路径图页面看到了这个效果: 有点像时间轴的赶脚,而且每一块鼠标悬浮上去也有下拉效果展开介绍截图信息,就感觉效果还不错.但感觉这种效果貌似对于动态添加不是很灵活,因为高度不像宽度可以灵活的自适应,故添加得自己一个一个设置.所以很多都是做成展示效果. 当然啦,自己也基于它的这个想法搞了一点简单点的类似效果,主要还是整个布局效果,具体每一块内容就不仿造了,而且我自己也加了一下开场动画,让它更好玩一

Android -- 时间轴(ListView)

1. 实现效果 如果判断当前的属性和上一个属性相同时,不显示编号信息 ,否则就显示 2.  主要是在适配器上面做判断 bean  --> Tip package com.example.timetest; /** * 封装要显示数据的bean ---> Tip * * @author Administrator * */ public class Tip { private String name; private String time; private String day; privat

Android 时间轴TimeLine

代码:这里