前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >gif-drawable的使用及详解

gif-drawable的使用及详解

作者头像
用户3030674
发布2018-09-14 15:00:53
1.7K0
发布2018-09-14 15:00:53
举报

下载gif-drawable包和Demo的链接:http://pan.baidu.com/s/1eQxVKRo

本帖原创,转载的朋友请注明转载地址》:http://www.cnblogs.com/zxxiaoxia/

    好久没有写博客了,今天来更新一下。

最近研究了一下图片发现这个控件还是不错的。所以给大家分享一下。

1、解压文件

将文件解压会发现有这样一系列的文件

2、添加文件到libs目录下

然后在eclipse或者idea(Android studio也是一样的)建一个工程,将这些文件导入进去。

添加到libs文件目录下

我们的环境就搭建完成了。

3、写布局文件

代码:

<pl.droidsonroids.gif.GifImageView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:src="@drawable/src_anim"
    android:background="@drawable/bg_anim"
    />

这里多说一下,gif-Drawable一共提供了3中可以显示动态图片的控件:GifImageViewGifImageButtonGifTextView。当需要赋的图像值是gif格式的图片的时候,会显示动态图片,如果是普通的静态图片,例如是png,jpg的,这个时候,gifImageView等这些控件的效果和ImageView是一样的。也就是说gif-drawable比ImageView更强大。

这里是GIFTextView的示例:

<pl.droidsonroids.gif.GifTextView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:drawableTop="@drawable/left_anim"
    android:drawableStart="@drawable/left_anim"
    android:background="@drawable/bg_anim"
    />

 这时候运行一下gif图片就已经可以显示了。

4、进阶:控制gif图片,停止播放动态图和开始动态图

gif-drawable这个控件,实际上是实现了AnimatableMediaPlayerControl这两个接口。

所以可以通过以下方法来控制动画:

  • stop() - 停止动画
  • start() - 开始动画
  • isRunning() - 判断动画是否在播放状态
  • reset() -重置动画
  • setSpeed(float factor) - 设置新动画播放速度 例如setSpeed(2.0f),动画会以二倍的速度进行播放
  • getDuration() - 返回动画播放的时间

其实控制gif图片和控制VideoView是一样的,

下面是代码示例:

/**
	 * 
	 * @author Sky
	 *
	 */
	@Override
    protected void onCreate ( Bundle savedInstanceState )
    {
        super.onCreate( savedInstanceState );
        
        GifImageButton gib = new GifImageButton( this );
        setContentView( gib );
        gib.setImageResource( R.drawable.sample );
        //上的3行代码也可以通过下面代码实现,是同理的,通过布局来获得空间
        //setContentView(R.layout.activity_main);
		//GifImageView gifImageView=(GifImageView) findViewById(R.id.gigImageview);
        
        //获取控制器
        final MediaController mc = new MediaController( this );
        //将图片放入媒体控制器中
        mc.setMediaPlayer( ( GifDrawable ) gib.getDrawable() );
        mc.setAnchorView( gib );
        //给图片添加监听,点击就会显示播放控件
        gib.setOnClickListener( new OnClickListener()
        {
            @Override
            public void onClick ( View v )
            {
                mc.show();
            }
        } );
    }

小提示:

有的朋友可能下了代码之后会不能运行。

需要修改project.properties文件下的版本

还有可能是资源图片需要换成你个人的文件。

要是还有问题可以留言的

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015-05-06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档