溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android中如何使用Glide框架

發(fā)布時(shí)間:2021-07-12 11:31:00 來源:億速云 閱讀:131 作者:Leah 欄目:移動開發(fā)

本篇文章為大家展示了Android中如何使用Glide框架,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

加載網(wǎng)絡(luò)圖片

引入對應(yīng)的庫

compile 'com.android.support:recyclerview-v7:25.0.0'compile 'com.github.bumptech.glide:glide:3.7.0'

創(chuàng)建RecyclerView的布局res/layout/fragment_list.xml

<?xml version="1.0" encoding="utf-8"?><android.support.v7.widget.RecyclerView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/recycler_view"></android.support.v7.widget.RecyclerView>

創(chuàng)建RecyclerView的每個(gè)item的布局 res/layout/list_item.xml

需要注意不要都寫成match_parentwrap_content,不然就顯示不出來瀑布流的效果

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="wrap_content">
    <ImageView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:adjustViewBounds="true"
        android:id="@+id/image"/></LinearLayout>

創(chuàng)建RecyclerView的適配器,GankAdapter.java,主要的代碼邏輯如下

@Overridepublic ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View v = LayoutInflater.from(mContext).inflate(R.layout.list_item,parent,false);    return new ViewHolder(v);
}@Overridepublic void onBindViewHolder(ViewHolder holder, int position) {    final String url = mItems.get(position);
    Log.e("tag","============onBindViewHolder url: "+url);
    Glide.with(mContext)
            .load(url)
            .placeholder(R.mipmap.ic_launcher)
            .diskCacheStrategy(DiskCacheStrategy.RESULT)
            .into(holder.image);
    holder.image.setOnClickListener(new View.OnClickListener(){        @Override
        public void onClick(View v) {
            Intent intent = new Intent();
            intent.setClass(mContext,PreviewImageActivity.class);
            intent.putExtra("url",url);
            mContext.startActivity(intent);
        }
    });
}@Overridepublic int getItemCount() {    return mItems.size();
}public class ViewHolder extends RecyclerView.ViewHolder{
     ImageView image;    public ViewHolder(View itemView) {        super(itemView);
        image = (ImageView)itemView.findViewById(R.id.image);
    }
}

顯示RecyclerView,創(chuàng)建一個(gè)Fragment來顯示 GankFragment.java
主要的顯示邏輯如下:

@Nullable@Overridepublic View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    View v = inflater.inflate(R.layout.fragment_list,container,false);
    mClient = new OkHttpClient();
    mReyclerView = (RecyclerView) v.findViewById(R.id.recycler_view);
    mReyclerView.setLayoutManager(new StaggeredGridLayoutManager(2,StaggeredGridLayoutManager.VERTICAL));
    mAdapter = new GankAdapter(getActivity(),mUrls);
    mReyclerView.setAdapter(mAdapter);
    loadApi(index);
    mReyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {        @Override
        public void onScrollStateChanged(RecyclerView recyclerView, int newState) {            super.onScrollStateChanged(recyclerView, newState);
        }        @Override
        public void onScrolled(RecyclerView recyclerView, int dx, int dy) {            super.onScrolled(recyclerView, dx, dy);            if(isScrollToEnd(mReyclerView)){
                Log.e("tag","============scroll to end");
                index += 1;
                loadApi(index);
            }
        }
    });    return v;
}

為了加載網(wǎng)絡(luò)圖片,引入了OkHttpClient的第三方庫

compile 'com.squareup.okhttp3:okhttp:3.4.1'

加載網(wǎng)絡(luò)的圖片的邏輯

private void loadApi(int page){
  Request request = new Request.Builder().url("http://gank.io/api/data/%E7%A6%8F%E5%88%A9/10/"+page).build();
  mClient.newCall(request).enqueue(new Callback() {      @Override
      public void onFailure(Call call, IOException e) {
          Log.e("tag","loading failure ");
          e.printStackTrace();
      }      @Override
      public void onResponse(Call call, Response response) throws IOException {          if(response.isSuccessful()){
              String result = response.body().string();              try {
                  JSONObject json = new JSONObject(result);
                  JSONArray array = new JSONArray(json.getString("results"));                  for(int i = 0;i<array.length();i++){
                      JSONObject ob = array.getJSONObject(i);
                      mUrls.add(ob.getString("url"));
                      Log.e("tag","========== url: "+ob.getString("url"));
                  }
                  mHandler.sendEmptyMessage(2);
              }catch (JSONException e){
                  e.printStackTrace();
              }
          }
      }
  });
}

Android中如何使用Glide框架

image.png

加載本地圖片

使用Glide加載本地圖片,和網(wǎng)絡(luò)圖片使用的是同一個(gè)適配器的代碼GankAdapter.java
顯示邏輯代碼LocalAlbumFragment.java,主要是從本地圖像數(shù)據(jù)庫中加載數(shù)據(jù)

private void loadAlbum(){
  AsyncTask<Void, Void, Void> asyncTask = new AsyncTask<Void, Void, Void>() {      @Override
      protected Void doInBackground(Void... params) {
          Cursor  c = getContext().getContentResolver().query(MediaStore.Images.Media.EXTERNAL_CONTENT_URI,                  new String[]{MediaStore.Images.ImageColumns.DATA},null,null, MediaStore.Images.ImageColumns.DATE_TAKEN+" desc ");          if(null != c && c.getCount() > 0 && c.moveToFirst()){              while (c.moveToNext()){
                  mData.add(c.getString(c.getColumnIndex(MediaStore.Images.ImageColumns.DATA)));
              }
          }          return null;
      }      @Override
      protected void onPostExecute(Void aVoid) {
          mHandler.sendEmptyMessage(2);
      }
  };
  asyncTask.execute();
}

Android中如何使用Glide框架

添加圖像變換

使用Glide庫時(shí),可以對圖像做一些變換處理,如:圓角,模糊等處理,使用Glide.bitmapTransform()方法,
自己需要寫對應(yīng)的變換的方法,但是現(xiàn)在有很好的第三方庫已經(jīng)對一些常用的變換做了封裝,可以直接使用,不要重復(fù)造輪子
引入第三方圖像變換庫 :glide-transformations

compile 'jp.wasabeef:glide-transformations:2.0.1'

這個(gè)庫提供很多的變換,如 剪裁相關(guān)的,顏色變化相關(guān)的,模糊相關(guān)的等,具體的請參考 源碼
試用了一個(gè)圓形的效果

Glide.with(mContext)
              .load(url)
              .placeholder(R.mipmap.ic_launcher)
              .diskCacheStrategy(DiskCacheStrategy.RESULT)
              .bitmapTransform(new CropCircleTransformation(mContext)) //使用圓形變換,還可以使用其他的變換
              .into(holder.image);

上述內(nèi)容就是Android中如何使用Glide框架,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI