ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Android ListView仿手机qq主页面

2021-05-03 18:32:22  阅读:224  来源: 互联网

标签:qq public convertView import Android ListView friends android


ListView的使用

仿照个人qq主页面

  • 原图

在这里插入图片描述

  • 效果图
    在这里插入图片描述
  1. 首先删除原来的工具栏
    在values文件夹下的styles文件中将style标签中的parent改为NoActionBar
    parent="Theme.AppCompat.Light.NoActionBar"
  2. 在activity_main.xml中创建一个Toolbar作为自己创建的工具栏,搜索框是抠图作为一个imageButton(原手机qq这个搜索框个人认为就是一个button)
    在这里插入图片描述
<androidx.appcompat.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="@color/blue"
            app:title="看客"
            app:titleTextColor="@color/write"
            android:paddingStart="15dp"
            android:paddingLeft="15dp"
            app:navigationIcon="@drawable/yonc"
            tools:ignore="RtlSymmetry"/>

    <ImageButton
            android:id="@+id/ib_search"
            android:layout_width="408sp"
            android:layout_height="55sp"
            android:src="@drawable/search_dark"
    />

ListView部分

  1. 在xml布局文件中创建一个ListView
    android:divider="@color/transparent"可以设置每一个item的下划线为透明色即无下划线
<ListView
            android:id="@+id/lv"
            android:layout_width="match_parent"
            android:layout_height="match_parent"/>
  1. 为ListView的每一个item创建一个布局
    这里仿照qq主页面的item创建一个布局(即一个个头像加一个昵称)
    其中的宽高可以根据图片的大小以及效果微调
    在这里插入图片描述
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              xmlns:tools="http://schemas.android.com/tools" android:orientation="horizontal"
              android:layout_width="match_parent"
              android:layout_height="55sp" tools:ignore="UseCompoundDrawables">

    <ImageView
            android:layout_gravity="center_vertical"
            android:id="@+id/icon_group"
            android:paddingStart="15dp"
            android:paddingLeft="15dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            tools:ignore="RtlSymmetry"/>
    <TextView
            android:paddingStart="15dp"
            android:paddingLeft="15dp"
            android:id="@+id/name_group"
            android:layout_width="wrap_content"
            android:textSize="20sp"
            android:layout_height="wrap_content" tools:ignore="RtlSymmetry"/>
</LinearLayout>
  1. 为ListView获取数据
    我这里是创建了一个javaBean名为FriendsBean,有name和icon属性,get和set方法没有贴出来
public class FriendsBean {
    private String name;
    private int icon;
    }

并且手动写入上述数据并且将相应的对象写入friends集合中。

  1. 创建一个适配器类继承BaseAdapter
    (详看注释)
package com.example.mylistview;

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

import java.util.List;

public class MyAdapter extends BaseAdapter {
    private List<FriendsBean> friends;
    private Context context;

    //构造方法
    public MyAdapter(List<FriendsBean> friends, Context context) {
        this.friends = friends;
        this.context = context;
    }

    //item的数量,定义为集合的长度
    @Override
    public int getCount() {
        return friends.size();
    }

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

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

    //将每一个item条目进行设置并且返回一个View
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        //拿到一个布局
        if (convertView==null){
            convertView = LayoutInflater.from(context)
                    .inflate(R.layout.list_item,parent,false);
        }
        //通过convertView对象拿到创建的布局中的子控件并且为之写入数据
        TextView textView = convertView.findViewById(R.id.name_group);
        textView.setText(friends.get(position).getName());
        ImageView imageView = convertView.findViewById(R.id.icon_group);
        imageView.setImageResource(friends.get(position).getIcon());
        return convertView;
    }
}

  1. 在MainActivity中调用
ListView listView = (ListView)findViewById(R.id.lv);
listView.setAdapter(new MyAdapter(friends,this));

标签:qq,public,convertView,import,Android,ListView,friends,android
来源: https://blog.csdn.net/weixin_44141172/article/details/116378045

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有