ListView的用法和滚动条用法

ListView 是手机系统上应用非常非常广泛的一种组件,它以垂直列表的形式显示所有列表项。

一、怎样去布局ListView

ListView额外提供如图以下的xml属性:



android:divider="#000"设置分割条为纯黑色

android:dividerHeight="3sp" 设置分割条高度为3dp

android:divider="@drawable/news_test1" 设置分割条为图片news_test1 

android:entries="@array/books" 指定books列表数组,还需在应用中定义一个名为books的数组,一般是提供Adapter


布局ListView的一个条目item的布局:当布局好ListView之后,可以根据需要对每个条目进行布局,以新闻的条目为例如下:


   
   

   
   

    
    
    

    
    
    

        
     
     

        
     
     
    
    
    
	

   
   
条目中的初始数据可以假设初设定。当代码进行操作后,会产生如下布局:

在条目上分别设有图片、新闻题目、新闻内容简介。

二、代码组成和适配器Adapter
先看下代码:
package com.itheima.news_listview.adapter;

import java.util.ArrayList;

import com.itheima.news_listview.R;
import com.itheima.news_listview.bean.NewsBean;

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.ImageView;
import android.widget.TextView;

public class NewsAdapter extends BaseAdapter {
	
	private ArrayList
    
    
     
      list;
	private Context context;

	public NewsAdapter(Context context,ArrayList
     
     
      
       list){
		this.list = list;
		this.context = context;
	}

	@Override
	public int getCount() {
		return list == null?0:list.size();
	}

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

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

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		Log.i("TAG", "$$$$$$$$$$$$"+position);
		View view = null;
		if(convertView != null){
			view = convertView;
		}else {
			LayoutInflater layoutInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
			view = layoutInflater.inflate(R.layout.item_news_layout, null);
			
		}
		//获取子控件的对象
		ImageView item_img_icon = (ImageView) view.findViewById(R.id.item_img_icon);
		TextView item_tv_des = (TextView) view.findViewById(R.id.item_tv_des);
		TextView item_tv_title = (TextView) view.findViewById(R.id.item_tv_title);
//		获取postion位置的对应list集合中的新闻数据
		NewsBean newsBean = list.get(position);
		//设置标题
		item_tv_title.setText(newsBean.title);
		//设置内容
		item_tv_des.setText(newsBean.des);
		
		item_img_icon.setImageDrawable(newsBean.icon);
		
		return view;
	}

}
     
     
    
    

先讲ListView和Adapter怎样工作的:
每当有一个条目暴露在屏幕下,adapter适配器就会为这个条目创建出item布局。每次滑动就会把新暴露出来的条目进行加载。在代码中添加的打印:Log.i("TAG", "$$$$$$$$$$$$创建的条目个数为:"+position);如果当前代码如下:
public View getView(int position, View convertView, ViewGroup parent) {
		Log.i("TAG", "$$$$$$$$$$$$创建的条目个数为:"+position);
		View view = null;
//		if(convertView != null){
//			view = convertView;
//		}else {
			LayoutInflater layoutInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
			view = layoutInflater.inflate(R.layout.item_news_layout, null);
			
		//}
		//获取子控件的对象
		ImageView item_img_icon = (ImageView) view.findViewById(R.id.item_img_icon);
		TextView item_tv_des = (TextView) view.findViewById(R.id.item_tv_des);
		TextView item_tv_title = (TextView) view.findViewById(R.id.item_tv_title);
//		获取postion位置的对应list集合中的新闻数据
		NewsBean newsBean = list.get(position);
		//设置标题
		item_tv_title.setText(newsBean.title);
		//设置内容
		item_tv_des.setText(newsBean.des);
		
		item_img_icon.setImageDrawable(newsBean.icon);
		
		return view;
	}
}
当滑动ListView时,LogCat的反馈应用信息如下:

创建太多的条目,占用运行资源。但是,如果有1万条条目时,不可能去全部加载出来。故会添加一个判断,复用已经完全消失在屏幕的条目进行复用,只会产生屏幕显示的条目个数+1(头一个没有完成消失,新暴露出来的已经加载,固此处要+1),代码如下:
public View getView(int position, View convertView, ViewGroup parent) {
		Log.i("TAG", "$$$$$$$$$$$$创建的条目个数为:" + position);
		View view = null;
		if (convertView != null) {
			view = convertView;
		} else {
			LayoutInflater layoutInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
			view = layoutInflater.inflate(R.layout.item_news_layout, null);

		}
		// 获取子控件的对象
		ImageView item_img_icon = (ImageView) view.findViewById(R.id.item_img_icon);
		TextView item_tv_des = (TextView) view.findViewById(R.id.item_tv_des);
		TextView item_tv_title = (TextView) view.findViewById(R.id.item_tv_title);
		// 获取postion位置的对应list集合中的新闻数据
		NewsBean newsBean = list.get(position);
		// 设置标题
		item_tv_title.setText(newsBean.title);
		// 设置内容
		item_tv_des.setText(newsBean.des);

		item_img_icon.setImageDrawable(newsBean.icon);

		return view;
	}
}
这样会把复用view=converView。

BaseAdapter的四个方法实现:
适配器的使用必须要实现4个方法,现在分别介绍4个方法的代表含义:

public int getCount() {
return list == null ? 0 : list.size();
}
有多少个项目放在适配器的数据中。返回一个int类型的数,此处返回一个数字的个数,但要用三目算法判断下数字是否为空。必须要判断下。

public Object getItem(int position) {
return list.get(position);
}
得到相关的数据项的指定位置的数据集,一般指对象数组的元素内容。返回一个Obj类型,此次数组存放的为对象

public long getItemId(int position) {
return position;
}
得到相关的行id列表中指定的位置 指item的id  返回一个long型

public View getView(int position, View convertView, ViewGroup parent) {
//得到一个视图显示数据集的数据在指定的位置。你可以手动创建一个视图或指定XML布局文件。
返回一个View布局的展示,这里要设置引入布局的各项参数

View view = null;
if (convertView != null) {
view = convertView;
//复用convertView
} else {
LayoutInflater layoutInflater = (LayoutInflater)                                  context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = layoutInflater.inflate(R.layout.item_news_layout, null);
//引用自己设定的xml布局格式
}
// 获取子控件的对象
ImageView item_img_icon = (ImageView) view.findViewById(R.id.item_img_icon);
//拿到图片
TextView item_tv_des = (TextView) view.findViewById(R.id.item_tv_des);
//拿到新闻内容
TextView item_tv_title = (TextView) view.findViewById(R.id.item_tv_title);
//拿到新闻题目
// 获取postion位置的对应list集合中的新闻数据
NewsBean newsBean = list.get(position);
// 设置标题
item_tv_title.setText(newsBean.title);
// 设置内容
item_tv_des.setText(newsBean.des);
// 设置图片
item_img_icon.setImageDrawable(newsBean.icon);
//显示当前条目内容
return view;
}
4个方法是关键,大部分是固定格式。

创建适配器和条目的点击监控:
先看主方法的代码:
package com.itheima.news_listview;

import java.util.ArrayList;

import com.itheima.news_listview.adapter.NewsAdapter;
import com.itheima.news_listview.bean.NewsBean;
import com.itheima.news_listview.utils.NewsUtils;

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;

public class MainActivity extends Activity implements OnItemClickListener {

	private Context mContext;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		mContext = this;
		//找到控件
		ListView lv_news = (ListView) findViewById(R.id.lv_news);
		ArrayList
    
    
     
      allNews = NewsUtils.getAllNews(mContext);
		//创建适配器adapter,把当前上下文和新闻资源传递
		NewsAdapter newsAdapter = new NewsAdapter(mContext, allNews);
		lv_news.setAdapter(newsAdapter);
//		设置条目的点击事件
		lv_news.setOnItemClickListener(this);				
	}
	@Override
	public void onItemClick(AdapterView
     
      parent, View view, int position,
			long id) {
		
		NewsBean bean = (NewsBean) parent.getItemAtPosition(position);
		
		String url = bean.news_url;
		
		Intent intent = new Intent();
		intent.setAction(Intent.ACTION_VIEW);
		intent.setData(Uri.parse(url));
		startActivity(intent);
	}
}
    
    
监控方法中有监控条目的方法,直接使用就行:
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
点击后需要执行的操作
}

滚动条的用法和属性:

当文字很多时View的高度不能超过一个固定的值,无法满足需求,因为ScrollView没有maxHeight,所以要了解其用法。
虽然Textview里面有方法可以实现该功能。如下:
    <TextView
    android:id="@+id/text_view"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:singleLine="false"
    android:maxLines="10"
    android:scrollbars="vertical"/>
但还有在java中设定:
TextView textView = (TextView)findViewById(R.id.text_view);
textView.setMovementMethod(ScrollingMovementMethod.getInstance());

上述方法需要在两个部分设定,过于麻烦,现在可以直接用ScrollView来实现滚动:代码如下:
<ScrollView
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<TextView 
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/tv_source"/>
</ScrollView>

也可以设定在横向的滚动HorizontalScrollView 代码如下

<HorizontalScrollView
        
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    >       
      <TextView 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/tv_source"/>
     </HorizontalScrollView>

也可以同时使用,外面套一层垂直的ScrollView就行,代码如下:
 <ScrollView 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
    <HorizontalScrollView
        
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        >
        
        <TextView 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/tv_source"/>
     </HorizontalScrollView>
    </ScrollView>

总结:需要掌握Adapter的4个方法,和设置item的点击事件。
学会布局ListView 和item的布局





  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ListView控件的滚动条可以重画,但是需要通过自定义绘制的方式实现。你可以通过继承ListView类,重写其onDraw方法,然后在该方法中绘制自定义的滚动条。在绘制滚动条时,你可以使用Canvas类提供的绘制API,比如drawRect、drawCircle等方法,来绘制滚动条的外观。另外,你也可以通过定义属性,来控制滚动条的颜色、宽度、形状等属性。需要注意的是,自定义绘制滚动条可能会对ListView的性能造成影响,因此应该在需要的情况下使用。 ### 回答2: ListView控件的滚动条是由系统自动绘制的,并不能直接进行重画。滚动条的绘制是由Android系统的UI框架负责的,开发者无法直接控制滚动条的绘制过程。滚动条的外观和行为取决于系统样式和主题设置。 如果开发者想要自定义滚动条的外观,可以通过修改主题的方式来实现。可以创建一个自定义的主题,在主题中指定滚动条的样式。然后在布局文件的根元素或ListView控件上应用此主题。这样ListView控件就会使用自定义的滚动条样式了。 另外,也可以考虑使用第三方库或自定义控件来实现更灵活的滚动条效果。一些开源的库可以提供高度可自定义的滚动条,开发者可以根据需要自行定制滚动条的样式和行为。 总结来说,ListView控件的滚动条本身不支持直接重画,但可以通过修改主题或使用第三方库实现滚动条的定制化。 ### 回答3: ListView控件的滚动条是由系统自动绘制的,我们无法直接重画滚动条。如果想要改变滚动条的样式或者行为,我们可以通过改变ListView的相关属性来间接实现。 首先,我们可以通过修改ListView的样式来改变滚动条的外观。可以使用自定义的滚动条样式来替代系统默认的滚动条样式。这可以通过在XML布局文件中设置ListView的android:scrollbarStyle属性来实现。 其次,我们可以通过设置ListView的相关属性来改变滚动条的行为。例如,我们可以通过设置android:scrollbars属性来指定滚动条何时显示。默认情况下,滚动条会在用户触摸ListView时显示,并在用户不再滚动ListView时自动消失。我们可以将android:scrollbars属性设置为"none"来禁用滚动条,或者设置为"vertical"或"horizontal"来永久显示相应方向的滚动条。 总而言之,虽然我们无法直接重画ListView控件的滚动条,但是我们可以通过修改ListView的样式和属性来间接实现改变滚动条的外观和行为。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值