Android实现快递物流跟踪布局效果

先看效果

首页Activity

public class TraceActivity extends AppCompatActivity {

  private ListView lvTrace;
  private List<Trace> traceList = new ArrayList<>(10);
  private TraceListAdapter adapter;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_trace);
    findView();
    initData();
  }

  private void findView() {
    lvTrace = (ListView) findViewById(R.id.lvTrace);
  }

  private void initData() {
    // 模拟一些假的数据
    traceList.add(new Trace("2016年11月18日 上午12:04:01", "在湖北武汉洪山区光谷公司长江社区便民服务站进行签收扫描,快件已被 已签收 签收"));
    traceList.add(new Trace("2016年11月18日 上午11:57:25", "在湖北武汉洪山区光谷公司长江社区便民服务站进行派件扫描;派送业务员:老王;联系电话:17786550311"));
    traceList.add(new Trace("2016年11月17日 下午4:43:29", "在湖北武汉洪山区光谷公司进行快件扫描,将发往:湖北武汉洪山区光谷公司长江社区便民服务站"));
    traceList.add(new Trace("2016年11月17日 上午9:11:21", "从湖北武汉分拨中心发出,本次转运目的地:湖北武汉洪山区光谷公司"));
    traceList.add(new Trace("2016年11月17日 上午1:53:14", "在湖南长沙分拨中心进行装车扫描,即将发往:湖北武汉分拨中心"));
    traceList.add(new Trace("2016年11月17日 上午1:50:18", "在分拨中心湖南长沙分拨中心进行称重扫描"));
    traceList.add(new Trace("2016年11月16日 上午11:27:58", "在湖南隆回县公司进行到件扫描"));
    adapter = new TraceListAdapter(this, traceList);
    lvTrace.setAdapter(adapter);
  }
}

然后适配器

public class TraceListAdapter extends BaseAdapter {
  private Context context;
  private List<Trace> traceList = new ArrayList<>(1);
  private static final int TYPE_TOP = 0x0000;
  private static final int TYPE_NORMAL= 0x0001;

  public TraceListAdapter(Context context, List<Trace> traceList) {
    this.context = context;
    this.traceList = traceList;
  }

  @Override
  public int getCount() {
    return traceList.size();
  }

  @Override
  public Trace getItem(int position) {
    return traceList.get(position);
  }

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

  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder holder;
    final Trace trace = getItem(position);
    if (convertView != null) {
      holder = (ViewHolder) convertView.getTag();
    } else {
      holder = new ViewHolder();
      convertView = LayoutInflater.from(context).inflate(R.layout.item_trace, parent, false);
      holder.tvAcceptTime = (TextView) convertView.findViewById(R.id.tvAcceptTime);
      holder.tvAcceptStation = (TextView) convertView.findViewById(R.id.tvAcceptStation);
      holder.tvTopLine = (TextView) convertView.findViewById(R.id.tvTopLine);
      holder.tvDot = (TextView) convertView.findViewById(R.id.tvDot);
      holder.tv_new = (TextView) convertView.findViewById(R.id.tv_new);
      convertView.setTag(holder);
    }

    if (getItemViewType(position) == TYPE_TOP) {
      // 第一行头的竖线不显示
      holder.tvTopLine.setVisibility(View.INVISIBLE);
      holder.tv_new.setVisibility(View.VISIBLE);
      // 字体颜色加深
      holder.tvAcceptTime.setTextColor(context.getResources().getColor(R.color.red));
      holder.tvAcceptStation.setTextColor(context.getResources().getColor(R.color.red));
      holder.tvDot.setBackgroundResource(R.drawable.timelline_dot_secord);
    } else if (getItemViewType(position) == TYPE_NORMAL) {
      holder.tvTopLine.setVisibility(View.VISIBLE);
      holder.tv_new.setVisibility(View.INVISIBLE);
      holder.tvAcceptTime.setTextColor(0xff999999);
      holder.tvAcceptStation.setTextColor(0xff999999);
      holder.tvDot.setBackgroundResource(R.drawable.timelline_dot_first);
    }

    holder.tvAcceptTime.setText(trace.getAcceptTime());
    holder.tvAcceptStation.setText(trace.getAcceptStation());
    return convertView;
  }

  @Override
  public int getItemViewType(int id) {
    if (id == 0) {
      return TYPE_TOP;
    }
    return TYPE_NORMAL;
  }

  static class ViewHolder {
    public TextView tvAcceptTime, tvAcceptStation;
    public TextView tvTopLine, tvDot,tv_new;
  }
}

实体类

public class Trace {
  /** 时间 */
  private String acceptTime;
  /** 描述 */
  private String acceptStation;

  public Trace() {
  }

  public Trace(String acceptTime, String acceptStation) {
    this.acceptTime = acceptTime;
    this.acceptStation = acceptStation;
  }

  public String getAcceptTime() {
    return acceptTime;
  }

  public void setAcceptTime(String acceptTime) {
    this.acceptTime = acceptTime;
  }

  public String getAcceptStation() {
    return acceptStation;
  }

  public void setAcceptStation(String acceptStation) {
    this.acceptStation = acceptStation;
  }
}

activity布局和item布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:id="@+id/activity_main"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical"
  android:background="@android:color/white"
  tools:context="cc.duduhuo.timelinedemo.TraceActivity">

  <ListView
    android:id="@+id/lvTrace"
    android:layout_width="match_parent"
    android:divider="@null"
    android:clickable="false"
    android:listSelector="@android:color/transparent"
    android:dividerHeight="0dp"
    android:layout_height="wrap_content" />
</LinearLayout>
<?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:gravity="center"
  android:orientation="horizontal">

  <RelativeLayout
    android:id="@+id/rlTimeline"
    android:layout_width="75dp"
    android:layout_height="match_parent">

    <TextView
      android:id="@+id/tvTopLine"
      android:layout_width="0.5dp"
      android:layout_height="12dp"
      android:layout_centerHorizontal="true"
      android:background="#999" />

    <TextView
      android:id="@+id/tvDot"
      android:layout_width="5dp"
      android:layout_height="5dp"
      android:layout_margin="2dp"
      android:layout_below="@id/tvTopLine"
      android:layout_centerHorizontal="true"
      android:background="@drawable/timelline_dot_normal" />

    <TextView
      android:layout_width="0.5dp"
      android:layout_height="match_parent"
      android:layout_below="@id/tvDot"
      android:layout_centerHorizontal="true"
      android:background="#999" />
    <TextView
      android:id="@+id/tv_new"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="最新"
      android:textColor="#ffffff"
      android:background="#ff0000"
      android:textSize="12sp"
      android:layout_marginLeft="3dp"
      android:paddingLeft="3dp"
      android:paddingRight="3dp"
      android:layout_toRightOf="@id/tvDot"
      android:layout_below="@id/tvTopLine"
      />
  </RelativeLayout>

  <RelativeLayout
    android:id="@+id/rlCenter"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="6dp"
    android:paddingRight="10dp"
    android:paddingLeft="10dp"
    android:paddingTop="6dp">

    <TextView
      android:id="@+id/tvAcceptTime"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="2014/06/24 20:55:28"
      android:textColor="#999"
      android:textSize="12sp" />

    <TextView
      android:id="@+id/tvAcceptStation"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_below="@id/tvAcceptTime"
      android:layout_marginTop="5dp"
      android:text="在湖南隆回县公司进行到件扫描"
      android:textColor="#999"
      android:textSize="12sp" />
  </RelativeLayout>
</LinearLayout>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android时光轴实现淘宝物流信息浏览效果

    本文实例为大家分享了Android时光轴的制作方法,供大家参考,具体内容如下 1. 效果 2.分析和实现 2.1效果实现: 之前想了一下这种效果,因为只需要用到自己的项目中所以采用图片直接布局的形式去实现效果,虽然效果实现了,但是后来发现了出了很多问题:第一Android的分辨率太多了直接设置xxxdp难免有部分机型出现不适配的情况,第二我们与右边这部分需要对齐的问题这个就比较头大. 所以目前的实现效果方式是这样子的: 1.自定义TimerLineMarker,根据自定义属性获取点和线的背景资源

  • Android仿淘宝物流信息TimeLineView

    淘宝物流信息TimeLine的制作方法: 仿照的TimeLine效果图: 代码实现: package com.zms.timelineview; import android.content.Context; import android.content.res.TypedArray; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import andro

  • Android ListView物流获取追踪功能实现

    ListView 控件可使用四种不同视图显示项目.通过此控件,可将项目组成带有或不带有列标头的列,并显示伴随的图标和文本. 最近在网上看到时间轴的布局效果,尝试按照这个原理,实现物流跟踪的效果,目前已经实现了,效果如下图 该效果完全是使用ListView来实现了,下面我们来看一下是如何实现的 (一):布局ListView并编写Item布局 首先需要在布局上面编写ListView: <RelativeLayout xmlns:android="http://schemas.android.c

  • Android实现快递物流跟踪布局效果

    先看效果 首页Activity public class TraceActivity extends AppCompatActivity { private ListView lvTrace; private List<Trace> traceList = new ArrayList<>(10); private TraceListAdapter adapter; @Override protected void onCreate(Bundle savedInstanceState

  • Android实现快递物流时间轴效果

    本文实例为大家分享了Android实现快递物流时间轴效果展示的具体代码,供大家参考,具体内容如下 首先,这篇参考了别人的代码.根据自己的项目需求简单改造了一下,效果图如下 xml:代码 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:lay

  • Android编程实现圆角边框布局效果的方法

    本文实例讲述了Android编程实现圆角边框布局效果的方法.分享给大家供大家参考,具体如下: 这里用的是TableLayout布局的.先看效果图 下面看下布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:Android="http://schemas.android.com/apk/res/android" android:layout_width=&

  • Android 实现伸缩布局效果示例代码

    最近项目实现下面的图示的效果,本来想用listview+gridview实现,但是貌似挺麻烦的于是就用flowlayout 来addview实现添加伸缩的效果,实现也比较简单. mainActivity 布局 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

  • Android 仿京东商城底部布局的选择效果(Selector 选择器的实现)

    京东商城的底部布局的选择效果看上去很复杂,其实很简单,这主要是要感谢 selector 选择器,本文将讲解仿照京东商城的底部布局的选择效果,如何实现 selector 选择器,在不同的状态下,给 view 设置不同的背景. 京东商城底部布局的选择效果如下. View主要的几种状态 主要状态有8种,设置状态的代码以及相应的含义如下. android:state_pressed = "true/false" //true表示按下状态,false表示非按下状态. android:state_

  • Android 自定义View实现任意布局的RadioGroup效果

    前言 RadioGroup是继承LinearLayout,只支持横向或者竖向两种布局.所以在某些情况,比如多行多列布局,RadioGroup就并不适用 . 本篇文章通过继承RelativeLayout实现自定义RadioGroup,实现RadioButton的任意布局.效果图如下: 代码(RelativeRadioGroup) /** * Author : BlackHao * Time : 2018/10/26 10:46 * Description : 自定义 RadioGroup */ p

  • Android编程之代码创建布局实例分析

    本文实例讲述了Android编程之代码创建布局使用方法.分享给大家供大家参考,具体如下: 大概描述一下效果:最外层是一个 RelativeLayout 里面有自定义个LinearLayout,每个LinearLayout有两个TextView.that's it !!! private void initView() { // 获取xml的RelativeLayout layout = (RelativeLayout) findViewById(R.id.liner); for (int i =

  • Android编程实现自定义渐变颜色效果详解

    本文实例讲述了Android编程实现自定义渐变颜色效果.分享给大家供大家参考,具体如下: 你是否已经厌恶了纯色的背景呢?那好,Android提供给程序员自定义渐变颜色的接口,让我们的界面炫起来吧. xml定义渐变颜色 首先,你在drawable目录下写一个xml,代码如下 <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.

  • Android ListView的Item点击效果的定制

    Android ListView的Item点击效果的定制           前言:           对于listview Android开发的朋友都知道用的很多,网上关于Android ListView的Item点击特效的文章很多,我自己也看了不少关于listview的文章,这里就记录下不错的文章,大家可以参考下, 在之前弄这个效果说真的很不明智,我是在Item的布局文件加个selector的xml文件来实现ListView的Item点击效果.. 这个算是我自己记录以后该如何使用的另一种方

  • Android实现广告图片轮播效果

    本文实例介绍了Android广告轮播图效果实现方法,分享给大家供大家参考,具体内容如下 首先看下一下布局文件: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:

随机推荐