您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關使用XListView如何加載圖片網絡,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
MainActivity.java
public class MainActivity extends AppCompatActivity { private XListView contents; private int page = 0; private MyBaseAdapter adapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); contents = findViewById(R.id.contents); adapter = new MyBaseAdapter(getLayoutInflater()); contents.setAdapter(adapter); //是否開啟下拉刷新 上拉加載 //contents.setPullRefreshEnable(false); contents.setPullLoadEnable(true); contents.setXListViewListener(new XListView.IXListViewListener() { @Override public void onRefresh() { page = 0; loadData(page); //加載刷新數據 } @Override public void onLoadMore() { loadData(page); } }); //一進來就去加載第一頁數據 loadData(page); } private String url = "http://apis.juhe.cn/cook/query?key=3ec004200a6a2f4cf4774e480c006375&menu=%E8%A5%BF%E7%BA%A2%E6%9F%BF&rn=10&pn="; private void loadData(int page) { String requestUrlWithPageNum = url + page; //加載網絡數據 new AsyncTask<String, Void, List<DataItem>>() { @Override protected List<DataItem> doInBackground(String... strings) { ResponseBean responseBean = null; try { URL url = new URL(strings[0]); HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection(); urlConnection.setRequestMethod("GET"); urlConnection.setConnectTimeout(5000); urlConnection.setReadTimeout(5000); int responseCode = urlConnection.getResponseCode(); if (responseCode == 200) { String str = stream2String(urlConnection.getInputStream()); responseBean = new Gson().fromJson(str, ResponseBean.class); } else { // } return responseBean == null ? null : responseBean.getResult().getData(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return null; } @Override protected void onPostExecute(List<DataItem> dataItems) { if (dataItems == null) { Toast.makeText(MainActivity.this, "請求數據錯誤", Toast.LENGTH_LONG).show(); return; } //更新數據 updateData(dataItems); loadCompleted(); } }.execute(url); } private String stream2String(InputStream is) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(is)); StringBuilder sb = new StringBuilder(); for (String tmp = br.readLine(); tmp != null; tmp = br.readLine()) { sb.append(tmp); } return sb.toString(); } private void updateData(List<DataItem> datas) { if (page == 0) { adapter.setDatas(datas); } else { adapter.addDatas(datas); } } //通過 加載 / 刷新 完成 private void loadCompleted() { //通過ListView:刷新、加載完成 page++; contents.stopLoadMore(); contents.stopRefresh(); } }
MyBaseAdapter.java
public class MyBaseAdapter extends BaseAdapter { private List<DataItem> mDatas; protected LayoutInflater mInflater; /** * 更新數據 */ public void setDatas(List<DataItem> datas) { mDatas.clear(); if (datas != null) { mDatas.addAll(datas); } notifyDataSetChanged(); } /** * 追加數據 */ public void addDatas(List<DataItem> datas) { if (datas != null) { mDatas.addAll(datas); notifyDataSetChanged(); } } public MyBaseAdapter(LayoutInflater mInflater) { this.mInflater = mInflater; mDatas = new ArrayList<>(); } @Override public int getCount() { return mDatas.size(); } @Override public DataItem getItem(int position) { return mDatas.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { BaseViewHolder viewHolder = null; if (convertView == null) { convertView = mInflater.inflate(R.layout.item, parent, false); viewHolder = new BaseViewHolder(convertView); } else { viewHolder = (BaseViewHolder) convertView.getTag(); } viewHolder.bindData(getItem(position)); return convertView; } public class BaseViewHolder { private View itemView; private ImageView icon; private TextView title; private TextView date; public BaseViewHolder(View itemView) { this.itemView = itemView; title = itemView.findViewById(R.id.title); date = itemView.findViewById(R.id.date); icon = itemView.findViewById(R.id.icon); itemView.setTag(this); } public void bindData(DataItem dataItem) { title.setText(dataItem.getTitle()); date.setText(dataItem.getId()); ImageLoader.getInstance().displayImage(dataItem.getFirstImageUrl(), icon, ImageLoaderConfigs.getDefaultDisplayImageOptions(icon.getContext())); } } } ImageLoader.java public class ImageLoaderConfigs { public static ImageLoaderConfiguration getImageLoaderConfiguration(Context context) { ImageLoaderConfiguration configuration = new ImageLoaderConfiguration.Builder(context) //內在緩存額外選項, 最大的寬度,高度 //.memoryCacheExtraOptions(480, 800) // default = device screen dimensions 內存緩存文件的最大長寬 //.diskCacheExtraOptions(480, 800, null) // 本地緩存的詳細信息(緩存的最大長寬),最好不要設置這個 //線程池配置 //.taskExecutor() //.taskExecutorForCachedImages() //.threadPoolSize(3) // default 線程池內加載的數量 //.threadPriority(Thread.NORM_PRIORITY - 2) // default 設置當前線程的優先級 //任務處理優先級 Fist In Fist Out //.tasksProcessingOrder(QueueProcessingType.FIFO) // default //內存中不緩存一張圖片的多個尺寸大小 //.denyCacheImageMultipleSizesInMemory() //內在緩存策略 //.memoryCache(new LruMemoryCache(2 * 1024 * 1024)) //可以通過自己的內存緩存實現 //內存緩存大小 //.memoryCacheSize(2 * 1024 * 1024) // 內存緩存的最大值 //內在緩存大小:占用百分比 .memoryCacheSizePercentage(13) // default //磁盤緩存策略 //.diskCache(new LruDiskCache()) // default 可以自定義緩存路徑 //磁盤緩存大小 .diskCacheSize(50 * 1024 * 1024) // 50 Mb sd卡(本地)緩存的最大值 //.diskCacheFileCount(100) // 可以緩存的文件數量 // default為使用HASHCODE對UIL進行加密命名, 還可以用MD5(new Md5FileNameGenerator())加密 //.diskCacheFileNameGenerator(new HashCodeFileNameGenerator()) //.imageDownloader(new BaseImageDownloader(context)) // default //(new BaseImageDecoder(false)) // default //加載具體圖片時的一些配置 .defaultDisplayImageOptions(DisplayImageOptions.createSimple()) // default .writeDebugLogs() // 打印debug log .build(); return configuration; } public static DisplayImageOptions getDefaultDisplayImageOptions(Context context) { DisplayImageOptions displayImageOptions = new DisplayImageOptions.Builder() //是否緩存 .cacheInMemory(true) .cacheOnDisk(true) //RGB 565 r紅色占5 g綠色占6 b藍色占5 -> 2字節 //alpha //ARGB 4444 4 4 4 4 -> 2字節 //ARGB 8888 -> 4字節 //10 * 10 用rgb565 -> 10*10*2 .bitmapConfig(Bitmap.Config.RGB_565) //加載時、加載錯誤時展示什么內容 .showImageOnLoading(R.mipmap.ic_launcher) .showImageOnFail(R.mipmap.ic_launcher) // .imageScaleType(ImageScaleType.EXACTLY_STRETCHED) //加載效果 //ctrl + p .displayer(new CircleBitmapDisplayer()) .build(); //ctrl + h //BitmapDisplayer; return displayImageOptions; } }
看完上述內容,你們對使用XListView如何加載圖片網絡有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。