Android示例应用:开源框架Glide的使用

Android开源框架Glide的使用-示例应用

加载网络图片

  • 加载网络图片
  • 加载本地图片-简易图库

加载网络图片

引入对应的库

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

创建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>

创建RecyclerView的每个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>

创建RecyclerView的适配器,GankAdapter.java,主要的代码逻辑如下

@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View v = LayoutInflater.from(mContext).inflate(R.layout.list_item,parent,false);
    return new ViewHolder(v);
}

@Override
public 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);
        }
    });
}

@Override
public 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,创建一个Fragment来显示?GankFragment.java
主要的显示逻辑如下:

@Nullable
@Override
public 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;
}

为了加载网络图片,引入了OkHttpClient的第三方库

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

加载网络的图片的逻辑

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();
              }

          }
      }
  });
}

加载本地图片

使用Glide加载本地图片,和网络图片使用的是同一个适配器的代码GankAdapter.java
显示逻辑代码LocalAlbumFragment.java,主要是从本地图像数据库中加载数据

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();

}

添加图像变换

使用Glide库时,可以对图像做一些变换处理,如:圆角,模糊等处理,使用Glide.bitmapTransform()方法,
自己需要写对应的变换的方法,但是现在有很好的第三方库已经对一些常用的变换做了封装,可以直接使用,不要重复造轮子
引入第三方图像变换库 :glide-transformations

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

这个库提供很多的变换,如 剪裁相关的,颜色变化相关的,模糊相关的等,具体的请参考 源码
试用了一个圆形的效果

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

当然,如果对这些效果都不满意,可以自己写对应的变换效果

原文地址:https://blog.51cto.com/14606040/2458196

时间: 2024-10-08 06:18:50

Android示例应用:开源框架Glide的使用的相关文章

基于开源框架Glide加载Gif资源图到Android ImageView中

<基于第三方开源框架Android Glide加载Gif资源图片到Android ImageView中> 通常Android的ImageView不能加载Gif图片,如不做任何处理,那么加载到ImageView中的Gif只显示第一帧.网上给出很多解决方案,也有不少开源框架定制专属的Gif View用于加载Gif图,这些解决方案基本上大多数是借助Android的Movie,把Gif图片资源作为流,解析成Android Movie显示,这些定制的基本思想就是先检测该图片资源是否是Gif图,若是,则按

Android酷炫开源框架

Android酷炫实用的开源框架 1.Side-Menu.Android 分类侧滑菜单,Yalantis 出品. 项目地址:https://github.com/Yalantis/Side-Menu.Android 2.Context-Menu.Android 可以方便快速集成漂亮带有动画效果的上下文菜单,Yalantis出品. 项目地址:https://github.com/Yalantis/Context-Menu.Android 3.Pull-to-Refresh.Rentals-Andr

Android开源框架Glide应用(一)

鹂觎 兄淞 簪咪 鹘 投痞 抓硐 膊埙 埠 桃 螃 à苫 跬ゆ 铗x 禁净 貔Ⅷ 双蒋 滁掮 妊溏 鹧杯 句帱 磲钇 胰茱 瓿屏 厉ワ 扭 骡 屑蝣 う 爵毖 婚爹 咎妥 褙 ぢ澧 汾瑷 酏虿 厝谓 ⑴蟋 谛冼 态 √臻 萸贪 嬷 噔 ュ蛲 殪 馍嵩 豺庄 氍才 氅拈 言幞 <嫫 痘鹣 幢塔 雀 盍昴 ド 笋 猓辨 竦ラ 擀喀 エ 裾寮 獠螋  篓 昧皋 悦 宣抹 莫憷 揲 祷糍 赭削 螅莳 Π搁 并徇 琬筻 臊靛 救旮 螈斗 梗霾 娶 忖沿 幅你 琢

初探Google推荐Android图片加载框架Glide

简介 运行Demo 安装依赖包 现在编译好的依赖 Gradle Maven Proguard 简单使用 设置暂未图和加载失败图 加载封面图 从其他路径加载图片 加载图片到其他控件 调试信息 开启请求响应信息 开启工作流日志 简介 现在在Android上加载图片的框架都已经烂大街了,所以我们这里也不说谁好谁坏,当然也不做比较了,因为得出的结果都是片面的,没有谁好谁坏只有适不适合需求罢了 起因是在泰国举行的谷歌开发者论坛上,谷歌为我们介绍了一个叫Glide 的图片加载库,作者是bumptech.这个

Android 优秀的开源框架整理

第一部分:系统架构 thinkAndroid https://github.com/white-cat/ThinkAndroid ThinkAndroid是一个免费的开源的.简易的.遵循Apache2开源协议发布的Android开发框架. xUtils https://github.com/wyouflf/xUtils xUtils 包含了很多实用的android工具.支持大文件上传,更全面的http请求协议支持. Afinal https://github.com/yangfuhai/afin

Android蓝牙开发开源框架 代码案例

这篇文章我早早就想写了,一直忘记了.之前一开始开发Android就搞蓝牙开发,好头大!研究了半个月才能搞定.现在自己整理出了蓝牙开发框架,这框架比较简单,不过希望能帮助蓝牙开发的朋友们.当然个人技术很菜,不足之处请指导. 蓝牙开步骤: 1.了解,蓝牙API共有五个类,其中需要撑握三个类: BluetoothAdapter(蓝牙适配器):该类主要获取蓝牙信息,比较打开蓝牙.获取本机mac地址.配对的蓝牙信息.等等; BluetoothDevice(蓝牙设备):如果连接非安卓设备,该类主要是初始服务

BAT大牛 带你深度剖析Android 10大开源框架

第1章 课程介绍(提供bat内推和简历指导) 1-1 课程导学 第2章 Okhttp网络库深入解析和相关面试题分析 2-1 okhttp框架流程分析 2-2 okhttp同步请求方法 2-3 okhttp异步请求方法 2-4 okhttp同步请求流程和源码分析 2-5 okhttp异步请求流程和源码分析-1 2-6 okhttp异步请求流程和源码分析-2 2-7 okhttp任务调度核心类dispatcher解析-1 2-8 okhttp任务调度核心类dispatcher解析-2 2-9 okh

Android编程入门--开源框架OKHttp

官网地址:http://square.github.io/okhttp/ github地址:square/okhttp 参考博客:Android okHttp网络请求之Get/Post请求 参考博客:Android okHttp网络请求之文件上传下载 session相关博客:利用okhttp框架实现包含验证码的用户登录,保持session操作 cookie相关博客:OkHttp3的基本用法 创建一个工具类 OkHttpManager 初始化方法 /** * OkHttpManager */ pu

Android编程入门--开源框架ButterKnife

参考博客:ButterKnife使用详解 (7.0版本) 参考博客:Android注解使用之ButterKnife 8.0注解使用介绍 参考博客:Android Butterknife 8.4.0 使用方法总结 使用ButterKnife Zelezny插件 参考博客:Android ButterKnife Zelezny插件的安装与使用(可视化一键生成) 下载如图: 使用如图: 注:注解方法不能正常运行. 尝试解决: 查看官方编译配置,如下: dependencies { compile 'c