首页 > 网名大全 正文
“qq列表设计“qq空间设计…

时间:2022-12-10 07:55:29 阅读: 评论: 作者:佚名

看标题这么高大上,实际上,还是运用我么拿到listview去扩展,我们讲什么呢,就是研究一下QQ,微信的这种对话列表,我们先看一个传统的ListView是怎么样的,我们做一个通讯录吧,通讯录的组成就是一个头像,一个名字,一个电话号码,一个点击拨打的按钮,既然这样,那我们的item就出来了

call_li

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

<LinearLayout xmlns:android=";

android:layout_width="match_parent"

android:layout_height="match_parent"

android:gravity="center_vertical"

android:orientation="horizontal">

<ImageView

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="center"

android:layout_weight="1"

android:src="@mipmap/ic_launcher" />

<TextView

android:id="@+id/tv_name"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="center"

android:layout_weight="1" />

<TextView

android:id="@+id/tv_number"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="center"

android:layout_weight="3" />

<Button

android:id="@+id/mCall"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="center"

android:layout_weight="1" />

</LinearLayout>

大家都知道,我们一个listview还是需要一个数据集,那我们就写一个java的实体类吧

Contentbean

package com.lgl.wec;

import android.widget.Button;

/**

* 实体类

*

* @author LGL

*/

public class ContentBean {

private String name;

private String number;

private Button mButton;

public String getName() {

return name;

}

public void setName(String name) {

= name;

}

public String getNumber() {

return number;

}

public void setNumber(String number) {

= number;

}

public Button getmButton() {

return mButton;

}

public void setmButton(Button mButton) {

= mButton;

}

}

传统的ListView,我相信大家都知道写,直接给出adapter

ContentAdapter

package com.lgl.wec;

import android.con;

import android.con;

import android.net.Uri;

import android.view.LayoutInflater;

import android.view.View;

import android.view.View.OnClickListener;

import android.view.ViewGroup;

import android.widget.BaseAdapter;

import android.widget.Button;

import android.widget.TextView;

import com.lgl.wec;

import com.lgl.wec.ContentBean;

import java.u;

public class ContentAdapter extends BaseAdapter {

private Context mContext;

private List<ContentBean> mList;

private LayoutInflater mInflater;

private ContentBean bean;

public ContentAdapter(Context mContext, List<ContentBean> mList) {

= mContext;

= mList;

mInflater = (LayoutInflater) mContext

.getSystemService);

}

@Override

public int getCount() {

// TODO Auto-generated method stub

return mLi();

}

@Override

public Object getItem(int position) {

// TODO Auto-generated method stub

return mLi(position);

}

@Override

public long getItemId(int position) {

// TODO Auto-generated method stub

return position;

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

ViewHodler viewHodler;

if (convertView == null) {

viewHodler = new ViewHodler();

convertView = mIn, null);

viewHodler.tv_name = (TextView) convertView

.findViewById);

viewHodler.tv_number = (TextView) convertView

.findViewById);

viewHodler.mCall = (Button) conver);

conver(viewHodler);

} else {

viewHodler = (ViewHodler) conver();

}

bean = mLi(position);

viewHodler.());

viewHodler.());

viewHodler.mCall.setText("拨打");

viewHodler.mCall.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

Call());

}

});

return convertView;

}

class ViewHodler {

private TextView tv_name;

private TextView tv_number;

private Button mCall;

}

/**

* 拨打电话

*

* @param phone

*/

public void Call(String phone) {

Intent intent = new Intent();

in("android.in;);

in("android.in;);

in("tel:"+phone));

mCon(intent);

}

}

当然,还需要在我们的主类中获取数据

package com.lgl.listview;

import java.u;

import java.u;

import android.a;

import android.da;

import android.os.Bundle;

import android.;

import android.widget.ListView;

public class MainActivity extends Activity {

private ListView mListView;

// 联系人集合

private List<String> contentName = new ArrayList<String>();

// 号码集合

private List<String> contentPhone = new ArrayList<String>();

private List<ContentBean> list = new ArrayList<ContentBean>();

@Override

protected void onCreate(Bundle savedInstanceState) {

(savedInstanceState);

setContentView);

getContent();

mListView = (ListView) findViewById);

for (int i = 0; i < con(); i++) {

ContentBean bean = new ContentBean();

bean.setName(i));

bean.setNumber(i));

li(bean);

}

ContentAdapter adapter = new ContentAdapter(this, list);

mLi(adapter);

}

/**

* 获取联系人

*/

private void getContent() {

Cursor query = getContentResolver().query(

Con, null, null,

null, null);

// 创建一个对象进行储存

String name; // 联系人

String phone; // 电话号码

// 我们获取到这些信息之后遍历出来

while ()) {

// 获取名字就需要P

name = query

.getString(query

.getColumnIndex(ContactsContract.CommonDataKinds.P));

// 获取num字段需要P

phone = query

.getString(query

.getColumnIndex(ContactsContract.CommonDataKinds.P));

con(name);

con(phone);

}

}

}

这样,一个简易的通讯录就做好了

OK,这个没什么问题,但是我们今天要讨论的,是一个对话的ListView,这在我们之前看的群英传一书中也提到过[Android群英传笔记——第四章:ListView使用技巧](http://blog.csdn.net/qq_26787115/article/details/50937767),但是讲的不是很详细,我们这里就多讲一下了,我们要区分左右,也就是type,需要用到getViewTypeCount()和getItemViewType()方法, 根据数据源的position返回需要显示的的layout的type,那我们从易到难,先写一个简单点的,就一个简单的文字对话框,怎么实现呢?我们当然得先定义left和right的item布局了

c

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

<LinearLayout xmlns:android=";

android:layout_width="match_parent"

android:layout_height="match_parent"

android:gravity="bottom"

android:orientation="horizontal"

android:padding="10dp">

<ImageView

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_marginLeft="20dp"

android:src="@mipmap/ic_launcher" />

<TextView

android:id="@+id/chatlist_tv_left"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_marginLeft="20dp"

android:background="@drawable/pop_left"

android:gravity="center"

android:padding="20dp" />

</LinearLayout>

c

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

<LinearLayout xmlns:android=";

android:layout_width="match_parent"

android:layout_height="match_parent"

android:gravity="right|bottom"

android:orientation="horizontal"

android:padding="10dp">

<TextView

android:id="@+id/chatlist_tv_right"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_marginRight="20dp"

android:background="@drawable/pop_right"

android:gravity="center"

android:padding="20dp" />

<ImageView

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_marginRight="20dp"

android:src="@mipmap/ic_launcher" />

</LinearLayout>

OK,别忘了这是一个新的listview,所以我们还得写一个实体类

ChatListBean

package com.lgl.wec;

/**

* 对话实体类

*

* @author LGL

*

*/

public class ChatListBean {

// 指定方向

private int type;

// 文本

private String value;

public int getType() {

return type;

}

public void setType(int type) {

= type;

}

public String getValue() {

return value;

}

public void setValue(String value) {

= value;

}

}

这样就对我们的adapter进行分析了

ChatListAdapter

package com.lgl.wec;

import android.con;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

import android.widget.BaseAdapter;

import android.widget.TextView;

import com.lgl.wec;

import com.lgl.wec.ChatListBean;

import java.u;

/**

* 对话ListView

*/

public class ChatListAdapter extends BaseAdapter {

public static final String KEY = "key";

public static final String VALUE = "value";

public static final int VALUE_LEFT_TEXT = 1;

public static final int VALUE_RIGHT_TEXT = 2;

private LayoutInflater mInflater;

private List<ChatListBean> myList;

public ChatListAdapter(Context context, List<ChatListBean> myList) {

= myList;

mInflater = (LayoutInflater) context

.getSystemService);

}

@Override

public int getCount() {

return myLi();

}

@Override

public Object getItem(int arg0) {

return myLi(arg0);

}

@Override

public long getItemId(int arg0) {

return arg0;

}

@Override

public View getView(int position, View convertView, ViewGroup arg2) {

ChatListBean msg = myLi(position);

int type = getItemViewType(position);

ViewHolderRightText holderRightText = null;

ViewHolderLeftText holderLeftText = null;

if (convertView == null) {

switch (type) {

// 左边

case VALUE_LEFT_TEXT:

holderLeftText = new ViewHolderLeftText();

convertView = mIn, null);

= (TextView) convertView

.findViewById);

.setText());

conver(holderLeftText);

break;

// 右边

case VALUE_RIGHT_TEXT:

holderRightText = new ViewHolderRightText();

convertView = mIn, null);

= (TextView) convertView

.findViewById);

.setText());

conver(holderRightText);

break;

}

} else {

switch (type) {

case VALUE_LEFT_TEXT:

holderLeftText = (ViewHolderLeftText) conver();

.setText());

break;

case VALUE_RIGHT_TEXT:

holderRightText = (ViewHolderRightText) conver();

.setText());

break;

}

}

return convertView;

}

/**

* 根据数据源的position返回需要显示的的layout的type

* <p/>

* type的值必须从0开始

*/

@Override

public int getItemViewType(int position) {

ChatListBean msg = myLi(position);

int type = m();

return type;

}

/**

* 返回所有的layout的数量

*/

@Override

public int getViewTypeCount() {

return 7;

}

// 左边的文本

class ViewHolderLeftText {

private TextView btnLeftText;

}

// 右边的文本

class ViewHolderRightText {

private TextView btnRightText;

}

}

我们去主类中写点数据

package com.lgl.wechatlist;

import android.os.Bundle;

import android.;

import android.;

import android.view.View;

import android.widget.Button;

import android.widget.ListView;

import com.lgl.wec.ChatListAdapter;

import com.lgl.wec.ChatListBean;

import java.u;

import java.u;

/**

* Created by LGL on 2016/5/7.

*/

public class QQActivity extends AppCompatActivity implements View.OnClickListener{

// 会话数据源

private List<ChatListBean> ListData;

// 会话Adapter

private ChatListAdapter chatListAdapter;

// 会话列表

private ListView mListView;

// 消息

private String message;

// 按钮

private Button btn_left, btn_right;

@Override

protected void onCreate(@Nullable Bundle savedInstanceState) {

(savedInstanceState);

setContentView);

mListView = (ListView) findViewById);

btn_left = (Button) findViewById);

b(this);

btn_right = (Button) findViewById);

b(this);

ListData = new ArrayList<ChatListBean>();

ChatListBean chatListBean = new ChatListBean();

c);

c("你好!");

Li(chatListBean);

chatListAdapter = new ChatListAdapter(this, ListData);

mLi(chatListAdapter);

}

@Override

public void onClick(View v) {

switch ()) {

case R.id.btn_left:

listLeft("left");

break;

case R.id.btn_right:

listRight("right");

break;

}

}

/**

* 显示列表左边

*

* @param text

*/

private void listLeft(String text) {

ChatListBean left = new ChatListBean();

le);

le(text);

Li(left);

c();

// 滚动到最底部

mLi());

}

/**

* 显示右边列表

*

* @param text

*/

private void listRight(String text) {

ChatListBean right = new ChatListBean();

rig);

rig(text);

Li(right);

c();

// 滚动到最底部

mLi());

}

}

好的运行一下

到这里,我们就对这个技巧有点熟悉了吧,既然如此,那我们即系,现在我们有6个item,分别是文字左右,图片左右,语言左右,这里就不贴出来了,要看的直接去Demo里面找哟,也没多少东西,就几个文本布局而已,我们直接来看实体类

MessageBean

package com.lgl.wec;

public class MessageBean {

private int type;//指定是哪种类型

private String value;//值

public int getType() {

return type;

}

public void setType(int type) {

= type;

}

public String getValue() {

return value;

}

public void setValue(String value) {

= value;

}

}

你一看,和上次那个没什么不同,对的,是没什么不同,只不过代码多了一点而已,这样的话,我们可以看Adapter了

package com.lgl.wec;

import android.con;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

import android.widget.BaseAdapter;

import android.widget.Button;

import android.widget.ImageView;

import android.widget.TextView;

import com.lgl.wec;

import com.lgl.wec.MessageBean;

import java.u;

/**

* 比原来的多了getItemViewType和getViewTypeCount这两个方法,

*

* */

public class WechatAdapter extends BaseAdapter {

public static final String KEY = "key";

public static final String VALUE = "value";

public static final int VALUE_LEFT_TEXT = 1;

public static final int VALUE_LEFT_IMAGE = 2;

public static final int VALUE_LEFT_AUDIO = 3;

public static final int VALUE_RIGHT_TEXT = 4;

public static final int VALUE_RIGHT_IMAGE = 5;

public static final int VALUE_RIGHT_AUDIO = 6;

private LayoutInflater mInflater;

private List<MessageBean> myList;

public WechatAdapter(Context context, List<MessageBean> myList) {

= myList;

mInflater = (LayoutInflater) context

.getSystemService);

}

@Override

public int getCount() {

return myLi();

}

@Override

public Object getItem(int arg0) {

return myLi(arg0);

}

@Override

public long getItemId(int arg0) {

return arg0;

}

@Override

public View getView(int position, View convertView, ViewGroup arg2) {

MessageBean msg = myLi(position);

int type = getItemViewType(position);

ViewHolderRightText holderRightText = null;

ViewHolderRightImg holderRightImg = null;

ViewHolderRightAudio holderRightAudio = null;

ViewHolderLeftText holderLeftText = null;

ViewHolderLeftImg holderLeftImg = null;

ViewHolderLeftAudio holderLeftAudio = null;

if (convertView == null) {

switch (type) {

// 左边

case VALUE_LEFT_TEXT:

holderLeftText = new ViewHolderLeftText();

convertView = mIn,

null);

= (ImageView) convertView

.findViewById);

= (Button) convertView

.findViewById_text);

.setText());

conver(holderLeftText);

break;

case VALUE_LEFT_IMAGE:

holderLeftImg = new ViewHolderLeftImg();

convertView = mIn,

null);

= (ImageView) convertView

.findViewById);

= (ImageView) convertView

.findViewById(R.id.iv_left_image);

.setImageResource);

conver(holderLeftImg);

break;

case VALUE_LEFT_AUDIO:

holderLeftAudio = new ViewHolderLeftAudio();

convertView = mIn,

null);

= (ImageView) convertView

.findViewById);

= (Button) convertView

.findViewById_audio);

= (TextView) convertView

.findViewById);

.setText());

conver(holderLeftAudio);

break;

// 右边

case VALUE_RIGHT_TEXT:

holderRightText= new ViewHolderRightText();

convertView = mIn,

null);

= (ImageView) convertView

.findViewById);

= (Button) convertView

.findViewById_text);

.setText());

conver(holderRightText);

break;

case VALUE_RIGHT_IMAGE:

holderRightImg= new ViewHolderRightImg();

convertView = mIn,

null);

= (ImageView) convertView

.findViewById);

= (ImageView) convertView

.findViewById(R.id.iv_right_image);

.setImageResource);

conver(holderRightImg);

break;

case VALUE_RIGHT_AUDIO:

holderRightAudio=new ViewHolderRightAudio();

convertView = mIn,

null);

= (ImageView) convertView

.findViewById);

= (Button) convertView

.findViewById_audio);

= (TextView) convertView

.findViewById);

.setText());

conver(holderRightAudio);

break;

default:

break;

}

} else {

switch (type) {

case VALUE_LEFT_TEXT:

holderLeftText=(ViewHolderLeftText)conver();

.setText());

break;

case VALUE_LEFT_IMAGE:

holderLeftImg=(ViewHolderLeftImg)conver();

.setImageResource);

break;

case VALUE_LEFT_AUDIO:

holderLeftAudio=(ViewHolderLeftAudio)conver();

.setText());

break;

case VALUE_RIGHT_TEXT:

holderRightText=(ViewHolderRightText)conver();

.setText());

break;

case VALUE_RIGHT_IMAGE:

holderRightImg=(ViewHolderRightImg)conver();

.setImageResource);

break;

case VALUE_RIGHT_AUDIO:

holderRightAudio=(ViewHolderRightAudio)conver();

.setText());

break;

default:

break;

}

//holder = (ViewHolder) conver();

}

return convertView;

}

/**

* 根据数据源的position返回需要显示的的layout的type

*

* type的值必须从0开始

*

* */

@Override

public int getItemViewType(int position) {

MessageBean msg = myLi(position);

int type = m();

return type;

}

/**

* 返回所有的layout的数量

*

* */

@Override

public int getViewTypeCount() {

return 7;

}

class ViewHolderRightText {

private ImageView ivRightIcon;// 右边的头像

private Button btnRightText;// 右边的文本

}

class ViewHolderRightImg {

private ImageView ivRightIcon;// 右边的头像

private ImageView ivRightImage;// 右边的图像

}

class ViewHolderRightAudio {

private ImageView ivRightIcon;// 右边的头像

private Button btnRightAudio;// 右边的声音

private TextView tvRightAudioTime;// 右边的声音时间

}

class ViewHolderLeftText {

private ImageView ivLeftIcon;// 左边的头像

private Button btnLeftText;// 左边的文本

}

class ViewHolderLeftImg {

private ImageView ivLeftIcon;// 左边的头像

private ImageView ivLeftImage;// 左边的图像

}

class ViewHolderLeftAudio {

private ImageView ivLeftIcon;// 左边的头像

private Button btnLeftAudio;// 左边的声音

private TextView tvLeftAudioTime;// 左边的声音时间

}

}

OK,代码清晰可见

我们的主类

package com.lgl.wechatlist;

import android.os.Bundle;

import android.;

import android.view.View;

import android.widget.ListView;

import com.lgl.wec.WechatAdapter;

import com.lgl.wec.MessageBean;

import java.u;

import java.u;

public class WechatActivity extends AppCompatActivity {

private ListView lvData;

private List<MessageBean> msgList;

private MessageBean msg;

private WechatAdapter adapter;

@Override

protected void onCreate(Bundle savedInstanceState) {

(savedInstanceState);

setContentView);

lvData = (ListView) findViewById);

msgList = new ArrayList<MessageBean>();

adapter = new WechatAdapter, msgList);

lvDa(adapter);

}

/**

* 左边文字

*

* @param v

*/

public void tv_left(View v) {

MessageBean msg = new MessageBean();

m);

m("我是文字左");

msgLi(msg);

ada();

//滑动到底部

lvDa());

}

/**

* 右边文字

*

* @param v

*/

public void tv_right(View v) {

MessageBean msg = new MessageBean();

m);

m("我是文字右");

msgLi(msg);

ada();

//滑动到底部

lvDa());

}

/**

* 左边图片

*

* @param v

*/

public void iv_left(View v) {

MessageBean msg = new MessageBean();

m);

m("我是图片左");

msgLi(msg);

ada();

//滑动到底部

lvDa());

}

/**

* 右边图片

*

* @param v

*/

public void iv_right(View v) {

msg = new MessageBean();

m);

m("我是图片右");

msgLi(msg);

ada();

//滑动到底部

lvDa());

}

/**

* 左边语音

*

* @param v

*/

public void iv_left_audio(View v) {

msg = new MessageBean();

m);

m("16s");

msgLi(msg);

ada();

//滑动到底部

lvDa());

}

/**

* 右边语音

*

* @param v

*/

public void iv_right_audio(View v) {

msg = new MessageBean();

m);

m("6s");

msgLi(msg);

ada();

//滑动到底部

lvDa());

}

}

那这样的话,我们运行一下

行,我们是不是已经有了大致的了解,我Demo也理得比较顺,要是看的不是很懂可以结合Demo来

Demo下载地址:

我的群,通往Android的神奇之旅 :555974449,欢迎大家进来交流技术!

  • 评论列表

发表评论: