博客
关于我
Movie播放Gif,完美实现屏幕适配
阅读量:793 次
发布时间:2023-02-09

本文共 2070 字,大约阅读时间需要 6 分钟。

android播放gif  我研究过3种

第一 :GifView支持android播放gif,效果是 先加载第一帧,然后慢慢加载完其他的针,这样效果视觉很不好,是从模糊到清晰的过程;
第二:是流行的把gif图片通过工具分拆成n帧,然后使用逐帧动画播放,我感觉很麻烦的样子;
第三 :使用Movie提供的Movie.decodeStream()方法解析gif,然后通过文件流的方式播放,效果特别好 ,和原图片没差
研究之后可以通过canvas实现对gif的拉伸,适配任何屏幕。
核心代码  自己加个layout,Activity测试
public class GifView extends View {
    private Movie mMovie;
    private long mMovieStart;
    
  
    private int mWidth, mHeight;
    private int mViewWidht, mViewHeight;
    private OnPlayListener onPlayListener;
    public GifView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        // TODO Auto-generated constructor stub
    }
    public GifView(Context context) {
        super(context);
        mMovie = Movie.decodeStream(getResources().openRawResource(
                R.raw.gif_anim));
    }
    public GifView(Context context, AttributeSet attrs) {
        super(context, attrs);
        //使用Movie解析gif图片
        mMovie = Movie.decodeStream(getResources().openRawResource( R.raw.gif_anim));
        //获得屏幕宽度,高度
        mWidth = BaseApplication.getInstance().screenWidth;
        mHeight = BaseApplication.getInstance().screenHeight;
        //gif图片宽度,高度
        mViewHeight = mMovie.height();
        mViewWidht = mMovie.width();
    }
        
    public OnPlayListener getOnPlayListener() {
        return onPlayListener;
    }
        
    public void setOnPlayListener(OnPlayListener onPlayListener) {
        this.onPlayListener = onPlayListener;
    }
    boolean isDraw = true;
    public void onDraw(Canvas canvas) {
        long now = android.os.SystemClock.uptimeMillis();
        if (isDraw) {
            if (mMovieStart == 0) { // first time
                mMovieStart = now;
            }
            if (mMovie != null) {
                int dur = mMovie.duration();
                if (dur == 0) {
                    dur = 5000;
                }
                //计算gif播放时间,gif播放完成,关闭界面
                if (now - mMovieStart >= dur) {
                    isDraw = false;
                    if (onPlayListener != null) {
                        onPlayListener.onFinished();
                    }
                }
                int relTime = (int) ((now - mMovieStart) % dur);
                mMovie.setTime(relTime);
                //根据屏幕大小计算缩放比例
                float saclex = (float) mWidth / (float) mViewWidht;
                float sacley = (float) mHeight / (float) mViewHeight;
                float sameRate = saclex > sacley ? saclex : sacley;
                canvas.scale(sameRate, sameRate);
                mMovie.draw(canvas, 0, 0);
                invalidate();
            }
        }
    }
        //gif关闭接口
    public static interface OnPlayListener {
        public void onFinished();
    }
}

转载地址:http://svffk.baihongyu.com/

你可能感兴趣的文章
Metasploit Windows AD渗透测试实战
查看>>
Metasploit 文件包含与跨站请求伪造渗透测试实战
查看>>
MFC 打印预览 映射模式 坐标变换
查看>>
MFC不规则窗体
查看>>
MFC之处理消息映射的步骤...
查看>>
MFC对话框屏幕居中
查看>>
MFC工作笔记0005---::在vc++中是什么意思
查看>>
MFC工作笔记0011---atoi的用法
查看>>
MFC数据类型
查看>>
MFC模态对话框和非模态对话框
查看>>
mha高可用
查看>>
Miaoo朋友圈程序全完整版源码
查看>>
Microsoft Security Updates API 使用教程
查看>>
Milesight VPN server.js 任意文件读取漏洞(CVE-2023-23907)
查看>>
MyBatis学习总结(6)——调用存储过程
查看>>
Mock.js 的语法规范学习
查看>>
mockcpp & testngpp在2010.7~11月的改进
查看>>
Mock在接口测试中的实际应用
查看>>
Mock模拟测试实战
查看>>
Modbus RTU串口通信实验
查看>>