Giter Club home page Giter Club logo

barragerenderer's People

Contributors

cornerant avatar evianzhow avatar parsifalc avatar unash avatar wongzigii avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

barragerenderer's Issues

在view上添加了弹幕,在程序运行期间崩溃

我的数据源是200条数据,当执行到200条之后就报了这个错误,是执行完还要什么操作吗?
libc++abi.dylib: terminate_handler unexpectedly threw an exception

  • (void)setAllViews{
    [self initBarrageRenderer];

    NSSafeObject * safeObj = [[NSSafeObject alloc]initWithObject:self withSelector:@selector(autoSendBarrage)];
    _timer = [NSTimer scheduledTimerWithTimeInterval:0.5 target:safeObj selector:@selector(excute) userInfo:nil repeats:YES];
    }

  • (void)initBarrageRenderer
    {
    _renderer = [[BarrageRenderer alloc]init];
    _renderer.view.backgroundColor = UIColorFromRGB(SubjectColorValue);
    _renderer.canvasMargin = UIEdgeInsetsMake(0, 0, 70, 0);

    [self addSubview:_renderer.view];
    [self sendSubviewToBack:_renderer.view];
    }

  • (void)setDataStartWith:(NSMutableArray *)loadArray{

    _modelArr = [NSMutableArray array];
    for (NSDictionary *tempDict in loadArray) {
    BarrageModel *model = [[BarrageModel alloc]initWithDict:tempDict];
    [_modelArr addObject:model];
    }
    [_renderer start];
    }

  • (void)autoSendBarrage{
    NSInteger spriteNumber = [_renderer spritesNumberWithName:nil];
    if (spriteNumber <= 20) {
    [_renderer receive:[self walkTextSpriteDescriptorWithDirection:BarrageWalkDirectionR2L]];
    }

}

  • (BarrageDescriptor *)walkTextSpriteDescriptorWithDirection:(NSInteger)direction
    {
    BarrageModel *model = _modelArr[_index];
    BarrageDescriptor * descriptor = [[BarrageDescriptor alloc]init];
    descriptor.spriteName = NSStringFromClass([BarrageWalkTextSprite class]);
    descriptor.params[@"text"] = [NSString stringWithFormat:@"%@ %@",model.UserNick,model.content];
    descriptor.params[@"textColor"] = [UIColor blueColor];
    descriptor.params[@"speed"] = @(100 * (double)random()/RAND_MAX+50);
    descriptor.params[@"direction"] = @(direction);
    descriptor.params[@"trackNumber"] = @20; // 轨道数量

    _index ++;
    return descriptor;

}

iOS10 swift3.0 使用pod 安装 按照demo写了一段代码,但是没有生成弹幕,log 显示弹幕数量一直为0,代码如下

import UIKit
class BarrageViewController: UIViewController {

let renderer = BarrageRenderer.init()
var timer: Timer?

override func viewDidLoad() {
    super.viewDidLoad()

    // Do any additional setup after loading the view.
    view.addSubview(renderer.view)
    renderer.canvasMargin = UIEdgeInsetsMake(10, 10, 10, 10)
    renderer.view.isUserInteractionEnabled = true
    view.sendSubview(toBack: renderer.view)
    

}


override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

override func viewDidAppear(_ animated: Bool) {
    super.viewDidAppear(animated)
    
    renderer.start()
    let safeObj = NSSafeObject.init(object: self, with: #selector(BarrageViewController.autoSendBarrage))
    if #available(iOS 10.0, *) {
        timer = Timer.scheduledTimer(timeInterval: 0.5, target: safeObj!, selector: #selector(NSSafeObject.excute), userInfo: nil, repeats: true)
    } else {
        // Fallback on earlier versions
        
    }
    
}


func autoSendBarrage() {
    let spriteNumber = renderer.spritesNumber(withName: nil)
    print("当前屏幕的弹幕数量: \(spriteNumber)")
    if spriteNumber < 100 {
        renderer.receive(walkTextSpriteDescription(withDirection: BarrageWalkDirection.R2L, side: BarrageWalkSide.left))
        renderer.receive(floatingTextSpriteDescriptor(withDirection: BarrageWalkDirection.B2T, side: BarrageFloatSide.center))
    }
}



func walkTextSpriteDescription(withDirection direction: BarrageWalkDirection, side: BarrageWalkSide) -> BarrageDescriptor {
    let descriptor = BarrageDescriptor()
    descriptor.spriteName = "walk"
    descriptor.params["attributedText"] = NSAttributedString.init(string: "过场文字: \(index = index + 1)", attributes: [NSForegroundColorAttributeName: UIColor.red, NSFontAttributeName: UIFont.systemFont(ofSize: 20)])

    descriptor.params["speed"] = NSNumber.init(value: 1.0)
    descriptor.params["direction"] = NSNumber.init(value: direction.rawValue)
    descriptor.params["side"] = NSNumber.init(value: side.rawValue)
    descriptor.params["clickAction"] = {
        print("click")
    }
    return descriptor
}

var index = 0
func floatingTextSpriteDescriptor(withDirection direction: BarrageWalkDirection, side: BarrageFloatSide) -> BarrageDescriptor {
    let descriptor = BarrageDescriptor()
    descriptor.spriteName = "floating"
    descriptor.params["text"] = "浮动文字: \(index = index + 1)"
    descriptor.params["textColor"] = UIColor.red
    descriptor.params["duration"] = NSNumber.init(value: 3)
    descriptor.params["fadeInTime"] = NSNumber.init(value: 1)

    descriptor.params["fadeOutTime"] = NSNumber.init(value: 1)
    descriptor.params["direction"] = NSNumber.init(value: direction.rawValue)
    descriptor.params["side"] = NSNumber.init(value: side.rawValue)
    return descriptor

}
deinit {
    renderer.stop()
}

}
`

Clock

/// 更新逻辑时间系统
- (void)updateTime
{
    NSDate * currentDate = [NSDate date];
    self.time += [currentDate timeIntervalSinceDate:_previousDate] * self.speed;
    _previousDate = currentDate;
}

这里每帧都会运行,构造 NSDate 开销可能比较大,只记时间戳可能好点

自定义表情图文混排问题。

请教图文混排问题:

我在descriptor.params里加入了attributedText字段,弹幕中无法显示。
是否需要进行其他设置?

绑定了delay 却没有从指定时间出来

NSLog(@"视频总长速度:%d",time);
NSMutableArray *descriptors = [NSMutableArray new];
for (int i = 0; i< time; i++) {
[descriptors addObject:[self walkTextSpriteDescriptorWithDirection:BarrageWalkDirectionR2L withIndex:i withAdd:NO]];
}
[_renderer load:descriptors];
[_renderer start];

index 为上述for循环里的 i ,delay是绑定事件参数,可是视频播放 弹幕却是一个脑儿得横着飘出来,视频播到一半 弹幕已经显示完全了
descriptor.params[@"delay"] = @(index);

手势无响应.

给的方法无效. 如果底层视图有手势,则不响应点击事件.

优化建议

添加一个缓存池存储弹幕,现在bindingView每次都要新建一个view
barrageImageScaleToSize里面试试用CoreImage替代CoreGraphics来处理图片

issue when Build

download project but can't run.这个下载下来就跑不了啊。需要什么特别设置?

循环播放

是否有循环播放的 feature?如果有的话怎么设置?

容器视图内存问题


您好,我在容器子视图内使用了您的弹幕,切换子视图都将子视图至为空,当第二次加载以前加载过的视图的时候会出现内存问题,请问是为什么呢。

弹幕精灵重叠问题

你好,当弹幕的展示区域较小,或者弹幕精灵的速度随机,或者某个时间段弹幕精灵的数量较多,都有一定概率出现某些弹幕精灵重叠在一起的情况,尽管可以通过spritesNumberWithName来限制精灵数量,但重叠的情况仍然会出现,求解决方案

BarrageClock.h请引入UIKit.h

我是复制的文件来编译为.a库的,这里少个引入,没什么大问题。

另外我想说我的效果是这样的:
从最左下方一行一行往上弹,发一个弹一个,最后发的在最下面,发一下把前面发的依次往上弹一个位置,就像聊天框那样的效果,不知道这个要用你的库怎么弄才好,给个思路吧。

请问没有碰撞检测么

比如在视频某个时间点有很多弹幕,这个时候所有弹幕都重叠在了一起,这个目前有解决方案么?

弹幕显示的区域/行数限制问题

当我设置弹幕view的edges之后,比如底部留下1/3的位置不显示,当横屏下弹幕数量较多,我切回竖屏的时候,屏幕上的弹幕会被切,view的布局更新了,但是弹幕本身的布局还是横屏的,就会被view的边缘砍到。
另:有没有灵活的改变字体大小的方法呢?
另:每次load都会导致所有弹幕全部从当前时间加载,而不会按照播放时间加载~descriptor能提供timestamp参数么,当前用的是delay

自定义图文混排弹幕

参考你demo中的图文混排弹幕继承于 BarrageWalkTextSprite 类,并且覆盖 - (UIView *)bindingView
和 - (CGSize)size 方法来实现自定义图文混排弹幕,demo中是直接 self.text 获取要展示的文本,但是当我文本较多并且有图片之类的元素该如何传值到自定义的这个类中并在 bindingView 中进行计算设置。

怎么设置轨道顺序?

现在默认第一轨道在顶部,第一条弹幕就是从最上面出来,有设置让第一个弹幕从最下面出来的方法吗?

崩溃问题

初始化的时候崩溃了。本人的需求是需要经常的添加,删除弹幕。(经常init,removeFromSuperView)

初始化代码如下:

private var render: BarrageRenderer! //弹幕

render = BarrageRenderer()
render.redisplay = true
renderBackgroundView.addSubview(render.view)
renderBackgroundView.sendSubviewToBack(render.view)
render.start()

崩溃信息如图:
qq20161019-0

seek之后暂停,时钟系统乱了

外部播放器seek 改变_predictedTime的值通过代理方法timeForBarrageRenderer: 传递到弹幕库,接着执行pause方法,时间好像乱了。

希望可以对初始显示的轨道,进行设置。

首先感谢作者的付出。
现在默认都是上往下,我希望第一个出现的轨道,是最底部的轨道。
我试着继承 BarrageWalkTextSprite , 然后覆盖- (CGPoint)originInBounds:(CGRect)rect withSprites:(NSArray *)sprites 返回你设置的弹幕初始位置.

- (CGPoint)originInBounds:(CGRect)rect withSprites:(NSArray *)sprites
{
    CGPoint point = [super originInBounds:rect withSprites:sprites];
    return point+200;
}

初始位置改变了,但是路线,变成了从”右下->左上“的斜线。

希望可以添加一个接口,设置初始显示的轨道。谢谢

关于弹幕颜色的问题

在设置弹幕的text时,如果text中不包含中文(测试过字母和数字混合),那么设置其颜色不起作用,显示为蓝色,且带下划线.只有当弹幕含有中文时,设置其颜色才起作用.text为NSTaggedPointerString类型,请问这种情况应该怎么解决?

error Barrage*6

Undefined symbols for architecture x86_64:
"OBJC_CLASS$_BarrageDescriptor", referenced from:
objc-class-ref in AdvancedBarrageController.o
"OBJC_CLASS$_BarrageRenderer", referenced from:
objc-class-ref in AdvancedBarrageController.o
"OBJC_CLASS$_BarrageWalkTextSprite", referenced from:
objc-class-ref in AdvancedBarrageController.o
OBJC_CLASS$_BarrageWalkImageTextSprite in BarrageWalkImageTextSprite.o
"OBJC_CLASS$_MLEmojiLabel", referenced from:
objc-class-ref in BarrageWalkImageTextSprite.o
"OBJC_METACLASS$_BarrageWalkTextSprite", referenced from:
OBJC_METACLASS$_BarrageWalkImageTextSprite in BarrageWalkImageTextSprite.o
ld: symbol(s) not found for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)

自定义View

最近在做直播的项目,恰好找到您这个BarrageRenderer,非常高兴,现在我想模仿其他App(inke)的弹幕功能,就是弹幕是在收到socket时动态产生,弹幕主题由用户头像、用户昵称、用户发言内容组成,要求用户头像可以点击,进入用户的个人主页,现在想请教下,这个能否用BarrageRenderer实现,并说下大致思路;或者自己写一个view,然后动画从右至左,然后解决复用;哪种比较好?

Engine

/// 冒泡法排序,值越大越往后
- (void)stackSpirits
{
    NSMutableArray * spirits = [NSMutableArray arrayWithArray:_spirits];
    NSInteger num = spirits.count;
    for (NSInteger i = 0; i < num - 1; i++) { //TODO: 这里如果num 换成 spirits.count, 会产生诡异的死循环
        for (NSInteger j = i+1; j < num; j++) {
            BarrageSpirit * spiritA = [spirits objectAtIndex:i];
            BarrageSpirit * spiritB = [spirits objectAtIndex:j];
            if (spiritA.z_index > spiritB.z_index) {
                [spirits exchangeObjectAtIndex:i withObjectAtIndex:j];
            }
        }
    }
    _spirits = [spirits copy];
}
  1. 排序不要自己去写,_spirits = [_spirits sortedArrayWith...]
  2. 产生死循环因为 sprits.countNSUInteger 无符号整型

视频快进快退弹幕处理

如果播放视频到15s,快退5s,这时是10s的时候。之前10s-15s播放过的弹幕不会再播放吗,需要再等到视频15s的时候才能继续播弹幕?
如果要实现10s-15s的时候播放快退前播放过的弹幕,应该怎么处理这块逻辑?

swift 3.0 会报错

start之后会报 -[_SwiftTypePreservingNSNumber length]: unrecognized selector sent to instance 0x60000043db80的错误,看了半天不太好定位具体的位置。。。。

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.