Picassoプレースホルダーにgifロード画像を表示するにはどうすればよいですか?
この部分でgifを使いたい
imageView = (ImageView) rootView.findViewById(R.id.imageView);
Picasso.with(getActivity()).load("http://joehamirbalabadan.com/Android/android/imghome/index1.png").placeholder(R.drawable.indexloading).into(imageView);
imageView3 = (ImageView) rootView.findViewById(R.id.imageView3);
Picasso.with(getActivity()).load("http://joehamirbalabadan.com/Android/android/imghome/index3.png").placeholder(R.drawable.indexloading).into(imageView3);
コードを確認して改善してください。
HomeFragment.Java
package com.example.administrator.mosbeau;
import Android.app.Activity;
import Android.app.Fragment;
import Android.app.FragmentManager;
import Android.graphics.Bitmap;
import Android.graphics.drawable.BitmapDrawable;
import Android.os.Bundle;
import Android.support.annotation.Nullable;
import Android.view.LayoutInflater;
import Android.view.View;
import Android.view.ViewGroup;
import Android.widget.ImageView;
import Android.widget.ProgressBar;
import com.squareup.picasso.Picasso;
/**
* Created by Administrator on 9/7/2015.
*/
public class HomeFragment extends Fragment {
public static HomeFragment newInstance() {
HomeFragment fragment = new HomeFragment();
return fragment;
}
public HomeFragment () {
}
Boolean InternetAvailable = false;
Seocnd detectconnection;
ImageView imageView, imageView3;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.homelayout, container, false);
detectconnection = new Seocnd(getActivity());
InternetAvailable = detectconnection.InternetConnecting();
if (InternetAvailable) {
imageView = (ImageView) rootView.findViewById(R.id.imageView);
Picasso.with(getActivity()).load("http://joehamirbalabadan.com/Android/android/imghome/index1.png").placeholder(R.drawable.indexloading).into(imageView);
imageView3 = (ImageView) rootView.findViewById(R.id.imageView3);
Picasso.with(getActivity()).load("http://joehamirbalabadan.com/Android/android/imghome/index3.png").placeholder(R.drawable.indexloading).into(imageView3);
} else {
NointernetFragment fragment = new NointernetFragment();
FragmentManager fragmentManager = getFragmentManager();
fragmentManager.beginTransaction()
.replace(R.id.container, fragment)
.commit();
}
return rootView;
}
@Override
public void onAttach(Activity activity) {
super.onAttach(activity);
((MainActivity) activity).onSectionAttached(1);
}
}
homelayout.xml
<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:layout_width="fill_parent"
Android:layout_height="wrap_content"
Android:orientation="horizontal"
Android:fillViewport="false"
Android:background="#fffff1f1">
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:layout_width="match_parent" Android:layout_height="match_parent"
Android:background="#fffff1f1"
Android:padding="10dp">
<ImageView
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:id="@+id/imageView"
Android:src="@drawable/index1"
Android:layout_alignParentEnd="false"
Android:layout_alignParentStart="false"
Android:layout_alignParentTop="false"
Android:layout_alignParentLeft="false"
Android:layout_alignParentRight="false"
Android:layout_alignWithParentIfMissing="false"
Android:adjustViewBounds="true"
Android:layout_marginBottom="10dp"
Android:layout_centerHorizontal="true"
Android:background="#ffffffff" />
<ImageView
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:id="@+id/imageView2"
Android:src="@drawable/index2"
Android:layout_below="@+id/imageView"
Android:adjustViewBounds="true"
Android:layout_marginBottom="10dp" />
<ImageView
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:id="@+id/imageView3"
Android:src="@drawable/index3"
Android:layout_below="@+id/imageView2"
Android:layout_alignParentBottom="true"
Android:adjustViewBounds="true"
Android:background="#ffffffff"
Android:layout_centerHorizontal="true" />
</RelativeLayout>
</ScrollView>
私が知っていることから、AndroidにはGIFのサポートが組み込まれていません。したがって、ImageViewはデフォルトでGIFをサポートしていません。
画像のロードとキャッシュにはGIFをサポートしているため、 Glideライブラリ を使用することをお勧めします。グライドはピカソに似ており、ピカソよりも優れていると見なされることがあります。使用されるメソッドもPicassoに似ていますが、GIFとしてImageViewに画像をロードできるasGif()メソッドがある点が異なります。
Glide.with(context)
.load(imageUrl)
.asGif()
.placeholder(R.drawable.loading_gif)
.into(imageView);
あなたがピカソ自体を使用することに非常に熱心であるなら、あなたはこれを調べる必要があるかもしれません stackoverflow post
picassoは画像ビュー用です。GIFファイルをwebViewで表示できますが、そのwebviewをpicasoで使用することはできません。
私はグライドでそれをします、あなたは拡張子gifでURLを入れて、それは機能します
Glide.with(getApplicationContext()).load("http://URL/estado2.gif").into(imageView);
ピカソはわかりません。ただし、IONライブラリにはGIFサポートが組み込まれています。 https://github.com/koush/ion