Fresco 圆形 圆角 动图

添加依赖:

 

compile 'com.facebook.fresco:fresco:0.12.0'
// 支持 GIF 动图,需要添加
  compile 'com.facebook.fresco:animated-gif:0.12.0'

  // 支持 WebP (静态图+动图),需要添加
  compile 'com.facebook.fresco:animated-webp:0.12.0'
  compile 'com.facebook.fresco:webpsupport:0.12.0'

  // 仅支持 WebP 静态图,需要添加
  compile 'com.facebook.fresco:webpsupport:0.12.0'

 

 

[MyApplication.java]
public class MyApplication extends Application {
	@Override
	public void onCreate() {
		super.onCreate();
		Fresco.initialize(this);
	}
}





fresco:fadeDuration="300" // 淡入淡出的持续时间

fresco:actualImageScaleType="focusCrop"  // 实际图像的缩放类型

fresco:placeholderImage="@color/wait_color"  //占位图

fresco:placeholderImageScaleType="fitCenter" //占位图的缩放类型

fresco:failureImage="@drawable/error" //下载失败显示的图片

fresco:failureImageScaleType="centerInside" //失败图的缩放类型

fresco:retryImage="@drawable/retrying"

//图片加载失败时显示,提示用户点击重新加载,重复加载4次还是没有加载出来的时候才会显示failureImage的图片

fresco:retryImageScaleType="centerCrop" //重新加载的图片缩放类型

fresco:progressBarImage="@drawable/progress_bar" //进度条图片

fresco:progressBarImageScaleType="centerInside"

fresco:progressBarAutoRotateInterval="1000"

//进度图自动旋转间隔时间(单位:毫秒ms)

fresco:backgroundImage="@color/blue"

//背景图片,这里的背景图片首先被绘制

fresco:overlayImage="@drawable/watermark"

// 设置叠加图,在xml中只能设置一张叠加图片,如果需要多张图片的话,需要在java代码中设置哦

fresco:pressedStateOverlayImage="@color/red"

// 设置点击状态下的叠加图

fresco:roundAsCircle="false" //设置为圆形图

fresco:roundedCornerRadius="1dp" // 圆角半径

fresco:roundTopLeft="true" // 左上角是否为圆角

fresco:roundTopRight="false"

fresco:roundBottomLeft="false"

fresco:roundBottomRight="true"

fresco:roundWithOverlayColor="@color/corner_color"

fresco:roundingBorderWidth="2dp" //边框的宽度

fresco:roundingBorderColor="@color/border_color" //边框颜色

 

 

 

 

圆角动图:

        

 SimpleDraweeView sld = (SimpleDraweeView)findViewById(R.id.sld);
 Uri ur = Uri.parse("https://upfile.asqql.com/2009pasdfasdfic2009s305985-ts/2018-4/20184202030624799.gif");
 sld.setImageURI(ur);
 //自动动图
 DraweeController controller = Fresco.newDraweeControllerBuilder()
         .setUri(ur)
         .setAutoPlayAnimations(true)
         .build();
 sld.setController(controller);
 //圆角
// GenericDraweeHierarchyBuilder builder = new GenericDraweeHierarchyBuilder(getResources());
 RoundingParams roundingParams = RoundingParams.fromCornersRadius(50f);
 roundingParams.setRoundAsCircle(true);
 roundingParams.setBorder(Color.BLUE,1);
 roundingParams.setOverlayColor(Color.WHITE);
 roundingParams.setCornersRadius(30f);
 sld.getHierarchy().setRoundingParams(roundingParams);

 

 

 

你可能感兴趣的:(Fresco 圆形 圆角 动图)