Fresco圖片載入的簡單應用
1.先註冊
public class MyApplication extends Application{ @Override public void onCreate() { super.onCreate(); Fresco.initialize(this); } }
2.開始顯示圖片
public class MainActivity extends AppCompatActivity { private SimpleDraweeView sdv,iv,icon; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } private void initView() { sdv = (SimpleDraweeView)findViewById(R.id.main_simple_drawee_view); // iv = (SimpleDraweeView)findViewById(R.id.iv); icon = (SimpleDraweeView)findViewById(R.id.icon); initData(); isGif(); } /** * 支援gif圖 */ private void isGif() { Uri uri = Uri.parse("http://p0.ifengimg.com/pmop/2018/0211/34BB8479C0B68ADA393B11E0FFA12AFA73C41CC4_size330_w423_h236.gif"); DraweeController controller = Fresco.newDraweeControllerBuilder() .setUri(uri) .setOldController(icon.getController())//記憶體優化 .setAutoPlayAnimations(true) .build(); icon.setController(controller); } private void initData() { Uri uri = Uri.parse("http://dynamic-image.yesky.com/740x-/uploadImages/2015/163/50/690V3VHW0P77.jpg"); // Uri uri = Uri.parse("http://p0.ifengimg.com/pmop/2018/0211/34BB8479C0B68ADA393B11E0FFA12AFA73C41CC4_size330_w423_h236.gif"); DraweeController controller = Fresco.newDraweeControllerBuilder() .setUri(uri) .setAutoPlayAnimations(true) .build(); sdv.setController(controller); } public void start(View view){ Animatable animatableStart = icon.getController().getAnimatable(); if(animatableStart != null&&!animatableStart.isRunning()){ animatableStart.start(); } } public void stop(View view){ Animatable animatableStop = icon.getController().getAnimatable(); if(animatableStop != null && animatableStop.isRunning()){ animatableStop.stop(); } } }
3.5 對應的佈局
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal"
xmlns:fresco="http://schemas.android.com/apk/res-auto">
<LinearLayout
android:orientation="vertical"
android:layout_width="0dp"
android:layout_weight="3"
android:layout_height="wrap_content">
<com.facebook.drawee.view.SimpleDraweeView
android:layout_width="400dp"
android:layout_height="200dp"
android:id="@+id/icon"
fresco:placeholderImage="@mipmap/ic_launcher"/>
<com.facebook.drawee.view.SimpleDraweeView
android:layout_width="400dp"
android:layout_height="500dp"
android:id="@+id/main_simple_drawee_view"
fresco:placeholderImage="@mipmap/ic_launcher"/>
</LinearLayout>
<LinearLayout
android:orientation="vertical"
android:layout_width="0dp"
android:layout_weight="1"
android:layout_height="wrap_content">
<Button
android:onClick="start"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="開始"/>
<Button
android:onClick="stop"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="暫停"/>
</LinearLayout>
</LinearLayout>
4.新增的依賴
compile 'com.facebook.fresco:fresco:0.11.0'
compile 'com.facebook.fresco:animated-gif:0.12.0'
別忘了註冊
android:name=".MyApplication"
<uses-permission android:name="android.permission.INTERNET"/>
相關文章
- Android圖片載入框架Fresco使用詳解Android框架
- 記一次Fresco載入圖片失敗的分析
- Android兩種簡單的載入GIF圖片的方法Android
- 單張圖片懶載入
- 實現一個簡單的基於 WebAssembly 的圖片處理應用Web
- 攻防世界-簡單的圖片
- 實現簡單的輪播圖(單張圖片、多張圖片)
- win10應用商店載入不出圖片如何解決_win10商店圖片載入不出來恢復方法Win10
- 使用代理模式改善SAP UI5應用的圖片載入體驗模式UI
- 圖片懶載入
- 圖片載入事件事件
- 預載入圖片
- Flutter 圖片載入Flutter
- 圖片預載入,圖片懶載入,和jsonp中的一個疑問JSON
- 圖片預載入和懶載入
- Fresco的圖片SimpleDraweeView設定ScaleType不起作用的問題View
- web前端入門到實戰:簡單的圖片輪播Web前端
- 載入本地圖片模糊,Glide載入網路圖片卻很清晰地圖IDE
- TestFlight下載App,載入圖片失效。Xcode安裝App,圖片載入正常。APPXCode
- Vue中圖片的載入方式Vue
- 圖片懶載入(IntersectionObserver)Server
- glide圖片載入原理IDE
- 圖片懶載入原理
- Android 圖片載入框架Android框架
- 載入遠端圖片
- 一圖搞懂Web應用的單點登入Web
- 不一樣的圖片載入方式
- C#開發BIMFACE系列53 WinForm程式中使用CefSharp載入模型圖紙1 簡單應用C#ORM模型
- jsp的簡單應用JS
- 圖片懶載入踩坑
- Android 高效安全載入圖片Android
- 解耦圖片載入庫解耦
- 圖片懶載入大白話
- 通用圖片載入元件UniversalImageLoader元件
- Js圖片懶載入(lazyload)JS
- Flutter載入圖片與GlideFlutterIDE
- 圖片懶載入實現
- 圖片下載 (hqm精簡版)