Fresco,作为图片加载框架,由大名鼎鼎的Facebook开发。比起其他的图片加载框架,由于导入了Native层代码的原因,使其功能相当强大。
综合来说,如果你的应用对图片的显示、加载等要求高的话,那就建议使用Fresco。但如果要求没那么高的话就用Glide或其它库吧。
事实上,Fresco是少有的拥有中文官方文档的框架,这对于想要深入学习的读者大有帮助,该网站为:Fresco 专为Android加载图片,这里就简单贴出由官网说明的一些关于Fresco的相关特性:
Bitmap
,占用大量的内存。大的内存占用势必引发更加频繁的GC。在5.0以下,GC将会显著地引发界面卡顿。Bitmap
,每一个动画都有很多帧。Fresco让你没有这些烦恼,它处理好每一帧并管理好你的内存。除了特性之外,Fresco具有的两大模块也需要说明一下:
鉴于Fresco的功能众多,API庞杂,这里限于作者学力所限仅展示最基础的图片加载功能,其余的拓展功能可以参看官方文档,官方文档写的相当详细了。
在使用任意框架之前,集成总是最先要做的。前往Fresco查看最新的依赖,然后修改module下的build.gradle,代码如下:
dependencies {
// 其他依赖
compile 'com.facebook.fresco:fresco:2.2.0'
}
在加载图片之前,你必须初始化Fresco类。你只需要调用Fresco.initialize
一次即可完成初始化,在 Application 里面做这件事再适合不过了(如下面的代码),注意多次的调用初始化是无意义的。
import android.app.Application;
import com.facebook.drawee.backends.pipeline.Fresco;
public class MyApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
Fresco.initialize(this);
}
}
做完上面的工作后,你需要在 AndroidManifest.xml 中指定你的 Application 类。为了下载网络图片,请确认你声明了网络请求的权限。
<manifest
...
>
<uses-permission android:name="android.permission.INTERNET" />
<application
...
android:label="@string/app_name"
android:name=".MyApplication"
>
...
</application>
...
</manifest>
注意:Fresco的底层调用了Native层的框架,使用前需要为项目配置NDK,如果没有NDK则需要下载(需要NDK版本号在20以上),项目配置即下图所示:
接下来,我们直接开始布局文件activity_main.xml的编写。该布局很简单,仅有一个按钮和一个由Fresco提供的SimpleDraweeView
控件(替代ImageView),代码如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:fresco="http://schemas.android.com/apk/res-auto"
tools:context=".MainActivity"
android:orientation="vertical">
<Button
android:id="@+id/btn_load_image"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="加载图片"/>
<com.facebook.drawee.view.SimpleDraweeView
android:id="@+id/iv_standard"
android:layout_width="100dp"
android:layout_height="100dp"
fresco:placeholderImage="@drawable/background"
/>
</LinearLayout>
在SimpleDraweeView控件中,fresco:placeholderImage
属性用于充当图片还未完全加载时的占位图。
之后,我们简单用字符串封装一下要请求的URL。这里封装一个URL,用于请求一个本地TomCat服务器中的图片,代码如下(服务器URL不固定,根据自己的服务器路径名进行相应修改):
mUri = Uri.parse("http://10.0.2.2:8080/tomcat.png");
这里直接在MainActivity中为按钮注册点击事件,然后调用相应api即可,代码如下:
btn_load_image.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
iv_standard.setImageURI(mUri);
}
});
注意,这里的iv_standard
是SimpleDraweeView控件的实例对象名。没错,只需要简单的加上setImageURI()
这句api,就可以实现图片加载的功能了。
本文地址:https://blog.csdn.net/qq_41151659/article/details/106131283
如对本文有疑问, 点击进行留言回复!!
Error running app: Default Activity Not Found
如何用HMS Nearby Service给自己的App添加近距离数据传输功能
BlockChain:2020年7月10日世界人工智能大会WAIC《链智未来 赋能产业区块链主题论坛》(四)
网友评论