Android 模拟新闻APP显示界面滑动优化实例代码

发布时间 - 2026-01-11 00:19:35    点击率:

内容:

1、滑动优化(滑动时不加载图片,停止才加载)

2、第一次进入时手动加载

代码如下:

1、界面布局

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:orientation="horizontal" android:layout_width="match_parent" 
 android:layout_height="wrap_content" 
 android:gravity="center"> 
 <ImageView 
  android:id="@+id/image" 
  android:src="@mipmap/ic_launcher" 
  android:layout_width="60dp" 
  android:layout_height="60dp" /> 
 <LinearLayout 
  android:orientation="vertical" 
  android:layout_marginLeft="10dp" 
  android:layout_width="match_parent" 
  android:layout_height="wrap_content"> 
  <TextView 
   android:id="@+id/title_tv" 
   android:text="TITLE" 
   android:textSize="15dp" 
   android:maxLines="1" 
   android:layout_width="match_parent" 
   android:layout_height="wrap_content" /> 
  <TextView 
   android:id="@+id/content_tv" 
   android:text="CONTENT" 
   android:textSize="10dp" 
   android:maxLines="3" 
   android:layout_width="match_parent" 
   android:layout_height="wrap_content" /> 
 </LinearLayout> 
</LinearLayout> 
<?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:id="@+id/activity_main" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:paddingBottom="@dimen/activity_vertical_margin" 
android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" 
tools:context="com.example.leixiansheng.news.MainActivity"> 
 <ListView 
  android:id="@+id/list_view" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent"> 
 </ListView> 
</RelativeLayout> 

2、开启异步解析数据

package com.example.leixiansheng.news; 
 
/** 
 * Created by Leixiansheng on 2017/3/21. 
 */ 
public class NewsBean { 
 public String viewUrl; 
 public String title; 
 public String content; 
} 
package com.example.leixiansheng.news; 
import android.os.AsyncTask; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.util.Log; 
import android.widget.ListView; 
import org.json.JSONArray; 
import org.json.JSONException; 
import org.json.JSONObject; 
import java.io.BufferedReader; 
import java.io.IOException; 
import java.io.InputStream; 
import java.io.InputStreamReader; 
import java.io.UnsupportedEncodingException; 
import java.net.URL; 
import java.util.ArrayList; 
import java.util.List; 
public class MainActivity extends AppCompatActivity { 
 private ListView listView; 
 private static String URL = "http://www.imooc.com/api/teacher?type=4&num=30"; 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_main); 
  listView = (ListView) findViewById(R.id.list_view); 
  new NewsAsyncTask().execute(URL); 
 } 
 //*&*异步加载,处理耗时任务,UI更新 
 class NewsAsyncTask extends AsyncTask<String, Void, List<NewsBean>> { 
  @Override 
  protected List<NewsBean> doInBackground(String... strings) { 
   return getJsonData(strings[0]); 
  } 
  @Override 
  protected void onPostExecute(List<NewsBean> newsBeen) { 
   super.onPostExecute(newsBeen); 
   NewsAdapter adapter = new NewsAdapter(MainActivity.this, newsBeen,listView); 
   listView.setAdapter(adapter); 
  } 
 } 
 //*&*JSON解析网页获取数据 
 private List<NewsBean> getJsonData(String url) { 
  List<NewsBean> newsBeanList = new ArrayList<>(); 
  try { 
   String jsonString = readSteam(new URL(url).openStream()); 
   Log.i("DATA", jsonString); 
   JSONObject jsonObject; 
   NewsBean newsBean; 
   try { 
    jsonObject = new JSONObject(jsonString); 
    JSONArray jsonArray = jsonObject.getJSONArray("data"); 
    for (int i = 0; i < jsonArray.length(); i++) { 
     jsonObject = jsonArray.getJSONObject(i); 
     newsBean = new NewsBean(); 
     newsBean.content = jsonObject.getString("description"); 
     newsBean.title = jsonObject.getString("name"); 
     newsBean.viewUrl = jsonObject.getString("picSmall"); 
     newsBeanList.add(newsBean); 
    } 
   } catch (JSONException e) { 
    e.printStackTrace(); 
   } 
  } catch (IOException e) { 
   e.printStackTrace(); 
  } 
  return newsBeanList; 
 } 
 //*&*读取数据流 
 private String readSteam(InputStream is) { 
  InputStreamReader isr; 
  String result = ""; 
  try { 
   String line = ""; 
   isr = new InputStreamReader(is, "utf-8"); 
   BufferedReader br = new BufferedReader(isr); 
   try { 
    while ((line = br.readLine()) != null) { 
     result += line; 
    } 
   } catch (IOException e) { 
    e.printStackTrace(); 
   } 
  } catch (UnsupportedEncodingException e) { 
   e.printStackTrace(); 
  } 
  return result; 
 } 
} 

3、自定义适配器(在此处设置滑动监听,以此来判断什么时候加载资源)

package com.example.leixiansheng.news; 
import android.content.Context; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.AbsListView; 
import android.widget.BaseAdapter; 
import android.widget.ImageView; 
import android.widget.ListView; 
import android.widget.TextView; 
import java.util.List; 
/** 
 * Created by Leixiansheng on 2017/3/21. 
 */ 
public class NewsAdapter extends BaseAdapter implements AbsListView.OnScrollListener{ 
 private List<NewsBean> newsBeanList; 
 private LayoutInflater inflater; 
 private ImageLoader imageLoader; //图片加载 
 private int start;  //第一个元素 
 private int end;  //最后一个元素 
 private boolean isFirstIn;  //是否第一次进入 
 public static String[] URLS;  //所有资源 
 public NewsAdapter(Context context, List<NewsBean> newsBeanList, ListView listView) { 
  this.newsBeanList = newsBeanList; 
  inflater = LayoutInflater.from(context); 
  imageLoader = new ImageLoader(listView); 
  URLS = new String[newsBeanList.size()]; 
  for (int i = 0; i < newsBeanList.size(); i++) { 
   URLS[i] = newsBeanList.get(i).viewUrl; 
  } 
  isFirstIn = true; 
  listView.setOnScrollListener(this); 
 } 
 @Override 
 public int getCount() { 
  return newsBeanList.size(); 
 } 
 @Override 
 public Object getItem(int i) { 
  return newsBeanList.get(i); 
 } 
 @Override 
 public long getItemId(int i) { 
  return i; 
 } 
 @Override 
 public View getView(int i, View view, ViewGroup viewGroup) { 
  ViewHolder viewHolder = null; 
  if (view == null) { 
   viewHolder = new ViewHolder(); 
   view = inflater.inflate(R.layout.item, null); 
   viewHolder.imageView = (ImageView) view.findViewById(R.id.image); 
   viewHolder.title = (TextView) view.findViewById(R.id.title_tv); 
   viewHolder.content = (TextView) view.findViewById(R.id.content_tv); 
   view.setTag(viewHolder); 
  } else { 
   viewHolder = (ViewHolder) view.getTag(); 
  } 
  String url = newsBeanList.get(i).viewUrl; 
  viewHolder.imageView.setImageResource(R.mipmap.ic_launcher); 
  //*&*设置标签,避免快速滑动listview出现位置误差 
  viewHolder.imageView.setTag(url); 
//  new ImageLoader().showImageByThread(viewHolder.imageView, url); 
  imageLoader.showImageViewByAsyncTask(viewHolder.imageView,url); 
  viewHolder.title.setText(newsBeanList.get(i).title); 
  viewHolder.content.setText(newsBeanList.get(i).content); 
  return view; 
 } 
 //*&*优化 
 class ViewHolder { 
  public TextView title; 
  public TextView content; 
  private ImageView imageView; 
 } 
 //滑动监听 
 @Override 
 public void onScrollStateChanged(AbsListView absListView, int i) { 
  if (i == SCROLL_STATE_IDLE) { 
   //停止状态:加载图片 
   imageLoader.loadImages(start, end); 
  } else { 
   //滑动状态:停止加载 
   imageLoader.cancelAllTasks(); 
  } 
 } 
 /** 
  * 
  * @param absListView 
  * @param i  第一个元素 
  * @param i1 元素数量 
  * @param i2 
  */ 
 @Override 
 public void onScroll(AbsListView absListView, int i, int i1, int i2) { 
  start = i; 
  end = i + i1; 
  //第一次进入需要手动加载 
  if (isFirstIn && i1 > 0) { 
   imageLoader.loadImages(start, end); 
   isFirstIn = false; 
  } 
 } 
} 
package com.example.leixiansheng.news; 
import android.graphics.Bitmap; 
import android.graphics.BitmapFactory; 
import android.os.AsyncTask; 
import android.os.Handler; 
import android.os.Message; 
import android.util.LruCache; 
import android.widget.ImageView; 
import android.widget.ListView; 
import java.io.BufferedInputStream; 
import java.io.IOException; 
import java.io.InputStream; 
import java.net.HttpURLConnection; 
import java.net.MalformedURLException; 
import java.net.URL; 
import java.util.HashSet; 
import java.util.Set; 
/** 
 * Created by Leixiansheng on 2017/3/21. 
 */ 
public class ImageLoader { 
 private ImageView mImageView; 
 private String mUrl; 
 //*&*创建缓存 
 private LruCache<String, Bitmap> lruCache; 
 private ListView listview; 
 private Set<NewsAsyncTask> mTask; 
 public ImageLoader(ListView listview) { 
  this.listview = listview; 
  mTask = new HashSet<>(); 
  //*&*获取最大内存 
  int maxMemory = (int) Runtime.getRuntime().maxMemory(); 
  //设置缓存大小 
  int lruCacheSize = maxMemory / 4; 
  lruCache = new LruCache<String, Bitmap>(lruCacheSize) { 
   @Override 
   protected int sizeOf(String key, Bitmap value) { 
    //获取每个数据大小 
    return value.getByteCount(); 
   } 
  }; 
 } 
 //添加数据到缓存 
 public void addBitmapToLruCache(String url, Bitmap bitmap) { 
  if (getBitmapFromLruCache(url) == null) { 
   lruCache.put(url, bitmap); 
  } 
 } 
 //从缓存中获取数据 
 public Bitmap getBitmapFromLruCache(String url) { 
  return lruCache.get(url); 
 } 
 private Handler handler = new Handler() { 
  @Override 
  public void handleMessage(Message msg) { 
   super.handleMessage(msg); 
   if (mImageView.getTag().equals(mUrl)) { 
    mImageView.setImageBitmap((Bitmap) msg.obj); 
   } 
  } 
 }; 
 public void showImageByThread(ImageView imageView, final String url) { 
  mImageView = imageView; 
  mUrl = url; 
  new Thread() { 
   @Override 
   public void run() { 
    super.run(); 
    Bitmap bitmap = getBitmapFromURL(url); 
    Message message = Message.obtain(); 
    message.obj = bitmap; 
    handler.sendMessage(message); 
   } 
  }.start(); 
 } 
 public Bitmap getBitmapFromURL(String urlString) { 
  Bitmap bitmap; 
  InputStream is = null; 
  try { 
   URL url = new URL(urlString); 
   HttpURLConnection connection = (HttpURLConnection) url.openConnection(); 
   is = new BufferedInputStream(connection.getInputStream()); 
   bitmap = BitmapFactory.decodeStream(is); 
   connection.disconnect(); 
   //模拟网速卡顿时 
//   try { 
//    Thread.sleep(1000); 
//   } catch (InterruptedException e) { 
//    e.printStackTrace(); 
//   } 
   return bitmap; 
  } catch (MalformedURLException e) { 
   e.printStackTrace(); 
  } catch (IOException e) { 
   e.printStackTrace(); 
  } finally { 
   try { 
    is.close(); 
   } catch (IOException e) { 
    e.printStackTrace(); 
   } 
  } 
  return null; 
 } 
 public void showImageViewByAsyncTask(ImageView imageView, String url) { 
  //判断是否已经缓存 
  Bitmap bitmap = getBitmapFromLruCache(url); 
  //没有缓存则从新下载 
  if (bitmap == null) { 
   imageView.setImageResource(R.mipmap.ic_launcher); 
  } else { 
   imageView.setImageBitmap(bitmap); 
  } 
 } 
 //加载从start到end的所有图片 
 public void loadImages(int start, int end) { 
  for (int i = start; i < end; i++) { 
   String url = NewsAdapter.URLS[i]; 
   //判断是否已经缓存 
   Bitmap bitmap = getBitmapFromLruCache(url); 
   //没有缓存则从新下载 
   if (bitmap == null) { 
    NewsAsyncTask task = new NewsAsyncTask(url); 
    task.execute(url); 
    mTask.add(task); 
   } else { 
    ImageView imageView = (ImageView) listview.findViewWithTag(url); 
    imageView.setImageBitmap(bitmap); 
   } 
  } 
 } 
 public void cancelAllTasks() { 
  if (mTask != null) { 
   for (NewsAsyncTask task : mTask) { 
    task.cancel(false); 
   } 
  } 
 } 
 private class NewsAsyncTask extends AsyncTask<String, Void, Bitmap> { 
//  private ImageView imageView; 
  private String url; 
  public NewsAsyncTask(String url) { 
//   this.imageView = imageView; 
   this.url = url; 
  } 
  @Override 
  protected Bitmap doInBackground(String... strings) { 
   String url = strings[0]; 
   //从网络获取图片 
   Bitmap bitmap = getBitmapFromURL(url); 
   if (bitmap != null) { 
    //将不在缓存中的图片加入到缓存 
    addBitmapToLruCache(url, bitmap); 
   } 
   return bitmap; 
  } 
  @Override 
  protected void onPostExecute(Bitmap bitmap) { 
   super.onPostExecute(bitmap); 
   ImageView imageView = (ImageView) listview.findViewWithTag(url); 
   if (imageView != null && bitmap != null) { 
    imageView.setImageBitmap(bitmap); 
   } 
   mTask.remove(this); 
  } 
 } 
} 

4、注册声明权限

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
 package="com.example.leixiansheng.news"> 
 <uses-permission android:name="android.permission.INTERNET"/> 
 <application 
  android:allowBackup="true" 
  android:icon="@mipmap/ic_launcher" 
  android:label="@string/app_name" 
  android:supportsRtl="true" 
  android:theme="@style/AppTheme"> 
  <activity android:name=".MainActivity"> 
   <intent-filter> 
    <action android:name="android.intent.action.MAIN" /> 
    <category android:name="android.intent.category.LAUNCHER" /> 
   </intent-filter> 
  </activity> 
 </application> 
</manifest> 

以上所述是小编给大家介绍的Android 模拟新闻APP显示界面滑动优化实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# android  # 新闻app  # 滑动优化  # Android实现雅虎新闻摘要加载视差动画效果  # Android仿网易新闻图片详情下滑隐藏效果示例代码  # Android开发实现自定义新闻加载页面功能实例  # Android UI设计与开发之PopupWindow仿腾讯新闻底部弹出菜单  # Android RecyclerView仿新闻头条的频道管理功能  # Android网络编程之简易新闻客户端  # Android模拟实现网易新闻客户端  # Android实现基本功能的新闻应用  # 加载  # 第一个  # 小编  # 判断是否  # 在此  # 什么时候  # 给大家  # 自定义  # 所有资源  # 所述  # 给我留言  # 感谢大家  # 疑问请  # 有任何  # IOException  # InputStreamReader  # InputStream  # BufferedReader  # String  # NewsBean 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】  Android自定义控件实现温度旋转按钮效果  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  如何在腾讯云服务器上快速搭建个人网站?  高防服务器租用如何选择配置与防御等级?  EditPlus中的正则表达式实战(6)  个人网站制作流程图片大全,个人网站如何注销?  如何在Tomcat中配置并部署网站项目?  python中快速进行多个字符替换的方法小结  在线制作视频网站免费,都有哪些好的动漫网站?  Laravel如何保护应用免受CSRF攻击?(原理和示例)  如何用腾讯建站主机快速创建免费网站?  原生JS实现图片轮播切换效果  如何在阿里云完成域名注册与建站?  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  如何在阿里云香港服务器快速搭建网站?  如何在宝塔面板创建新站点?  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  如何在阿里云部署织梦网站?  如何获取免费开源的自助建站系统源码?  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  EditPlus中的正则表达式 实战(2)  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  如何在IIS中新建站点并配置端口与物理路径?  如何用西部建站助手快速创建专业网站?  Laravel如何实现事件和监听器?(Event & Listener实战)  🚀拖拽式CMS建站能否实现高效与个性化并存?  javascript基于原型链的继承及call和apply函数用法分析  IOS倒计时设置UIButton标题title的抖动问题  如何自定义建站之星模板颜色并下载新样式?  ,网页ppt怎么弄成自己的ppt?  Angular 表单中正确绑定输入值以确保提交与验证正常工作  Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程  UC浏览器如何设置启动页 UC浏览器启动页设置方法  如何快速搭建支持数据库操作的智能建站平台?  iOS UIView常见属性方法小结  北京专业网站制作设计师招聘,北京白云观官方网站?  如何挑选最适合建站的高性能VPS主机?  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  C++时间戳转换成日期时间的步骤和示例代码  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  Android使用GridView实现日历的简单功能  高防服务器如何保障网站安全无虞?  如何制作一个表白网站视频,关于勇敢表白的小标题?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  网站制作免费,什么网站能看正片电影?  大同网页,大同瑞慈医院官网?  Linux系统命令中tree命令详解