ListView做一个简单的物价条

对listview界面的定制可以丰富界面的内容。首先我们需要准备一些相同类型的图片。

个人推荐图片网站:http://www.easyicon.net/ 设计师 比较喜欢。而且图片大小分辨率可以选择一致。

那么就先展示最终的效果吧:
最终效果图片

为了做出这样的效果(使用的是Android Studio),首先
分析一下,左边是一个图片imageView ,图片下边是一个textview 表示价格,右边也是一个textview 表示产品类别,水平垂直居中。
要达到如此效果,你需要创建如下的文件:

*Fruit.java作为listview内容的java类
FruitAdapter.java作为Fruit的适配器类
ManActivity.java就不用说了
activity_main.xml文件—–放置listview
fruit_item.xml文件—listview内部的图片和textview*
还需要把图片复制进来,放置在drawable文件夹下。

代码具体如下:
activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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" android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
    <ListView
        android:id="@+id/list_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    </ListView>
    <!-- image view 用于显示图片-->
</RelativeLayout>

fruit_item.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <ImageView
        android:id="@+id/fruit_image"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <!-- 价格 显示在图片的下方 调整一下距离-->
    <TextView
        android:id="@+id/price_item"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="50dp"
        android:layout_marginLeft="12dp"
        />
    <!-- 显示图片右边的文字的textview 垂直水平 居中-->
    <TextView
        android:id="@+id/fruit_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        />
</RelativeLayout>

Fruit.java

package com.example.administrator.app4;


public class Fruit {
    private String name;//name
    private String price;//price
    private int imageId;//图片id
    public Fruit(String name,int imageId,String price)//构造函数
    {
        this.name = name;//参数传值
        this.imageId = imageId;
        this.price = price;
    }
    //获得name
    public String getName()
    {
        return name;
    }
    //get peice
    public String getPrice()
    {
        return price;
    }
    //获得image id
    public int getImageId()
    {
        return imageId;
    }
}

FruitAdapter.java

package com.example.administrator.app4;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import java.util.List;

/**
 * Created by Administrator on 2016/3/17.
 * 这个类是创建 自定义的适配器
 * 继承至ArrayAdapter
 */
public class FruitAdapter extends ArrayAdapter<Fruit>{
    private int resource;
    public FruitAdapter(Context context, int textViewResourceId, List<Fruit> objects) {
        super(context,textViewResourceId, objects);
        resource = textViewResourceId;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        //获取当前项的Fruit实例
        Fruit fruit = getItem(position);
        View view = LayoutInflater.from(getContext()).inflate(resource, null);
        //findViewBuId
        ImageView fruitImage= (ImageView) view.findViewById(R.id.fruit_image);
        TextView priceText= (TextView) view.findViewById(R.id.price_item);
        TextView fruitName= (TextView) view.findViewById(R.id.fruit_name);
        //设置图片
        fruitImage.setImageResource(fruit.getImageId());
        //设置价格
        priceText.setText(fruit.getPrice());
        //设置文字
        fruitName.setText(fruit.getName());
        return view;

    }
}

MainActivty.java

package com.example.administrator.app4;

import android.app.Activity;
import android.os.Bundle;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.List;

public class MainActivity extends Activity {
    //声明 水果列表对象
    private List<Fruit> fruitList = new ArrayList<>();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initFruits();
        FruitAdapter fruitAdapter = new FruitAdapter(MainActivity.this,R.layout.fruit_item,fruitList);
        ListView listView = (ListView) findViewById(R.id.list_view);
        listView.setAdapter(fruitAdapter);
    }
    //初始化 水果列表数据
    public  void initFruits()
    {
        Fruit apple = new Fruit("苹果",R.drawable.image1,"1元");
        Fruit orang = new Fruit("番茄",R.drawable.image4,"2元");
        Fruit aaa = new Fruit("橘子",R.drawable.image2,"3元");
        Fruit bbb = new Fruit("沙拉",R.drawable.image3,"3元");
        Fruit ccc = new Fruit("草莓",R.drawable.image6,"2元");
        Fruit ddd = new Fruit("番茄",R.drawable.image4,"2.3元");
        Fruit eee = new Fruit("番茄",R.drawable.image5,"1元");
        Fruit fff = new Fruit("番茄",R.drawable.image2,"2元");
        Fruit ggg = new Fruit("番茄",R.drawable.image1,"3元");
        Fruit hhh = new Fruit("番茄",R.drawable.image3,"0.5元");

        fruitList.add(apple);
        fruitList.add(orang);
        fruitList.add(aaa);
        fruitList.add(bbb);
        fruitList.add(ccc);
        fruitList.add(ddd);
        fruitList.add(eee);
        fruitList.add(fff);
        fruitList.add(ggg);
        fruitList.add(hhh);


    }
}

图片下载地址:http://download.csdn.net/detail/dada111111111/9465806

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值