Android集成B站弹幕库Danmaku

DanmaKu简介

弹幕库是B站开发的一款开源的弹幕库引擎,非常火爆,号称烈焰弹幕使!
项目的github开源网址

特点

  • 使用多种方式(View/SurfaceView/TextureView)实现高效绘制

  • B站xml弹幕格式解析

  • 基础弹幕精确还原绘制

  • 支持mode7特殊弹幕

  • 多核机型优化,高效的预缓存机制

  • 支持多种显示效果选项实时切换

  • 实时弹幕显示支持

  • 换行弹幕支持/运动弹幕支持

  • 支持自定义字体

  • 支持多种弹幕参数设置

  • 支持多种方式的弹幕屏蔽

PS一句: B站的弹幕库确实开源的彻底,.so库源码都开源出来了,感谢无私奉献!

使用

效果图:
           这里写图片描述

1.添加依赖
repositories {
    jcenter()
}

dependencies {
    compile 'com.github.ctiao:DanmakuFlameMaster:0.8.3'
}
2.简单使用
  • 将弹幕DanmakuView添加到布局文件,覆盖在VideoView上方
<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true">

    <VideoView
        android:id="@+id/vv_video_play"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_centerInParent="true"/>

    <master.flame.danmaku.ui.widget.DanmakuView
        android:id="@+id/dmk_show_danmu"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

</RelativeLayout>
  • 在Activity中的使用步骤
//1. 实例化(此处使用的ButterKnife,使用findViewById(....),也是一样的)
DanmakuView mDmkView;
@BindView(R.id.dmk_controller)

//2. 创建一个DanmakuContext,用于配置弹幕的具体属性如:字体、显示行数、是否重叠等等
//为了简洁,我将配置DanmakuContext封装在了DanmakuConfigUtil类中,除了简洁,也方便修改,下文贴出
DanmakuContext mDmkContext = DanmakuConfigUtil.getDanmakuContext() ;

//3. 创建弹幕解析,为了简单此处使用默认解析(也是封装在了DanmakuConfigUtil类中)
BaseDanmakuParser mParser = DanmakuConfigUtil.getDefaultDanmakuParser() ;

//4. 设置监听
mDmkView.setCallback(new DrawHandler.Callback() {
  @Override
  public void prepared() {
    mDmkView.start();
  }
  ....
  ....
  //下面还有几个回调方法,本例中暂时用不到,不写了
}

//5. 弹幕准备,准备结束会在第4部回调,然后开始弹幕
mDmkView.prepare(mParser, mDmkContext);

//6. 添加一条弹幕,此处将生成一条弹幕也封装在了DanmakuConfigUtil类中
BaseDanmaku oneDanmu = DanmakuConfigUtil.getOneDanmu(this, mDmkContext, mDmkView.getCurrentTime(), content);
mDmkView.addDanmaku(oneDanmu);

使用B站弹幕库就是如此简单,就这么清晰的几步…,下面贴出DanmakuConfigUtil类
…….
…….
…….


/**
 * author yzm
 * description
 * Created by yzm on 2017/8/11.
 */

public class DanmakuConfigUtil {

    public static DanmakuContext getDanmakuContext(){

        //设置显示最大行数
        Map<Integer, Integer> maxLines = new HashMap<>() ;
        maxLines.put(BaseDanmaku.TYPE_SCROLL_RL, 5) ;

        //设置是否显示重叠
        Map<Integer, Boolean> overMap = new HashMap<>() ;
        overMap.put(BaseDanmaku.TYPE_SCROLL_RL, true) ;
        overMap.put(BaseDanmaku.TYPE_FIX_TOP,true) ;

        //实例化弹幕上下文
        DanmakuContext mDmkContext = DanmakuContext.create() ;
        mDmkContext
                .setDanmakuStyle(IDisplayer.DANMAKU_STYLE_STROKEN, 3)
                .setDuplicateMergingEnabled(false)  //不可重复合并
                .setScrollSpeedFactor(1.2f)   //设置滚动速度因子
                .setScaleTextSize(1.2f)    //弹幕字体缩放
                .setMaximumLines(maxLines)   //设置最大滚动行
                .preventOverlapping(overMap).setDanmakuMargin(40) ;
        return mDmkContext ;
    }

    /**
     * [通过指定文件流生成弹幕解析, 本例使用的是B站Sample中的弹幕资源]
     * @type {[type]}
     */
    public static BaseDanmakuParser getBaseDanmakuParser(InputStream is){
        if(is == null){
            return new BaseDanmakuParser() {
                @Override
                protected IDanmakus parse() {
                    return new Danmakus();
                }
            } ;
        }
        ILoader mLoader = DanmakuLoaderFactory.create(DanmakuLoaderFactory.TAG_BILI) ;
        try {
            mLoader.load(is);
        } catch (IllegalDataException e) {
            e.printStackTrace();
        }
        BaseDanmakuParser parser = new BiliDanmukuParser() ;
        IDataSource<?> dataSource = mLoader.getDataSource() ;
        parser.load(dataSource) ;
        return parser ;
    }

    /**
     * [生成默认解析]
     * @type {[type]}
     */
    public static BaseDanmakuParser getDefaultDanmakuParser(){
        return new BaseDanmakuParser() {
            @Override
            protected IDanmakus parse() {
                return new Danmakus();
            }
        } ;
    }

    /**
     * 获取一条弹幕
     * @param mDmkContext
     * @param time
     * @param content
     * @return
     */
    public static BaseDanmaku getOneDanmu(Context context, DanmakuContext mDmkContext,long time, String content){
        //创建一条从右侧开始滚动的弹幕
        BaseDanmaku danmaku = mDmkContext.mDanmakuFactory.createDanmaku(BaseDanmaku.TYPE_SCROLL_RL) ;
        if(danmaku == null || !danmaku.isPrepared()){
            return null ;
        }
        danmaku.text = content ;
        danmaku.padding = 5 ;
        danmaku.priority = 0 ;
        danmaku.isLive = true ;
        danmaku.setTime(time+1000);
        danmaku.textSize = sp2px(context,18f) ;
        danmaku.textColor = Color.RED ;
        danmaku.borderColor = Color.GREEN ;
        return danmaku ;
    }

    /**
     * sp转px的方法。
     */
    public static int sp2px(Context context, float spValue) {
        final float fontScale = context.getResources().getDisplayMetrics().scaledDensity;
        return (int) (spValue * fontScale + 0.5f);
    }
}

总结

Danmaku的使用暂时就这多,比较简单,没有更深入的研究,基本能满足现有需求,后续可能会再深入研究,自己也很期待…


Demo源码下载

Danmaku2ASS 用来将来自 Niconico/Acfun/Bilibili 的评论转成 ASS 格式,这样就可以在任意支持 ASS 字母的媒体播放器中使用弹幕。使用方法:usage: danmaku2ass.py [-h] [-f FORMAT] [-o OUTPUT] -s WIDTHxHEIGHT [-fn FONT]                       [-fs SIZE] [-a ALPHA] [-dm SECONDS] [-ds SECONDS]                       [-fl FILTER] [-p HEIGHT] [-r]                       FILE [FILE ...] positional arguments:   FILE                  Comment file to be processed optional arguments:   -h, --help            show this help message and exit   -f FORMAT, --format FORMAT                         Format of input file (autodetect|Bilibili|Tudou2|MioMi                         o|Acfun|Niconico|Tudou) [default: autodetect]   -o OUTPUT, --output OUTPUT                         Output file   -s WIDTHxHEIGHT, --size WIDTHxHEIGHT                         Stage size in pixels   -fn FONT, --font FONT                         Specify font face [default: sans-serif]   -fs SIZE, --fontsize SIZE                         Default font size [default: 25]   -a ALPHA, --alpha ALPHA                         Text opacity   -dm SECONDS, --duration-marquee SECONDS                         Duration of scrolling comment display [default: 5]   -ds SECONDS, --duration-still SECONDS                         Duration of still comment display [default: 5]   -fl FILTER, --filter FILTER                         Regular expression to filter comments   -p HEIGHT, --protect HEIGHT                         Reserve blank on the bottom of the stage   -r, --reduce          Reduce the amount of comments if stage is full 标签:Danmaku2ASS
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值