博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
跨平台的WebRTC客户端框架:OpenWebRTC
阅读量:6633 次
发布时间:2019-06-25

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

Webrtc的ios框架编译

http://www.th7.cn/Program/IOS/201502/390418.shtml

 

 

 : http://www.webrtcinwebkit.org/

 

 

 

OpenWebRTC was designed for flexibility and modularity. The bulk of the API layer is implemented in , making it super fast to modify and extend with new functionality. Below is a simplified sketch of the architecture.

OpenWebRTC 是基于 Gstreamer 实现的开源的、跨平台的 WebRTC 客户端框架,支持 H.264 和 VP8。利用 OpenWebRTC,WebRTC就不再仅仅是纯粹浏览器技术了,你可以在NativeAPP中使用WebRTC,并且还可以与浏览器WebRTC互联互通。\Simplified architecture

 

 

icon-projects.png

Based on GStreamer

Among  great projects, OpenWebRTC is built on top of widely used and powerful  multimedia framework.

 

 

 

 

Extension of UIWebView

 

Bowser is based on the official UIWebView provided by the platform and the  API's are implemented with JavaScript that is injected into web pages as they load, the injected JavaScript code is using remote procedure calls to control the  backend.

The  is to move to the WKWebView, introduced in  8, as soon as possible.

 

 

 

Background

 

Bowser was originally developed by Ericsson Research and released in October of 2012, for both iOS and  devices. Back then Bowser was the world's first WebRTC-enabled browser for mobile devices. Bowser was later removed from the Apple App Store and Google Play but was resurrected and released as Open Source together with OpenWebRTC.

 

 

 

 

 

·研究院通过推出自由开源的网页浏览器和底层框架,继续致力于WebRTC标准

·目前这一浏览器是iOS上唯一的WebRTC浏览器

·OpenWebRTC是一个灵活的跨平台WebRTC客户端框架,可用于构建本地 WebRTC应用和浏览器后端

C114讯 爱立信研究院日前宣布推出自由开源的网页浏览器Bowser和底层框架OpenWebRTC,旨在为开发人员提供更多的选择和更大的灵活性,从而进一步加快WebRTC(网页实时通信)领域的创新。

WebRTC提供了一种实时构建语音、视频及数据应用的超简单方法,WebRTC包括一系列的API及协议,万维网联盟(W3C)和工程任务组(IETF)正在对这些API和协议进行标准化。

OpenWebRTC依托的理念就是,WebRTC标准会超越纯浏览器环境,而本地应用会实现相同的协议和API,成为WebRTC生态系统的重要部分。在平台上尤其如此,发布本地应用通常比纯应用更可取。

图 :爱立信研究院研究主管Stefan Ålund

爱立信研究院研究主管Stefan Ålund表示:“我们在2012年推出了Bowser,获得了广泛欢迎。现在,我们不仅推出了Bowser,还推出了近几年一直在爱立信内部开发和使用的底层跨平台WebRTC框架。”

爱立信研究院积极参与 WebRTC的标准化进程,自成立以来一直致力于实现该标准的原型。此标准要实现,IETF和W3C均要求至少实现两个独立的、可互操作的标准。

Ålund继续说:“WebRTC标准仍在发展,开发人员也在不断寻找利用这一技术的新方法。我院工程师构建的OpenWebRTC ,可极其简单地进行修改和扩展,以便留出空间尝试更多的API及新特点。”

Bower作为开放源码推出,已提交至应用程序商店,很快就可免费下载。

 

 

 

 

 

 

Safari开始支持WebRTC

 2015年9月12日

 

 

 

WebRTC和WebKit

WebRTC是基于浏览器的实时通信接口,主要支持通过浏览器进行点对点的音频以及视频通信。WebRTC规范由和共同制定。通过这些API,Web开发者可以通过标准的JavaScript API在网页中嵌入视频、音频通信功能。

是一个开源的浏览器引擎,它由WebCore排版引擎、JSCore JavaScript引擎和各种平台移植代码组成。WebKit目前缺乏对WebRTC标准的支持,因此开发者构建了网站,开始在WebKit上加入对WebRTC的支持。最初,该项目在WebKit的GTK移植中使用增加对WebRTC支持,后续的支持,将会逐渐放入到WebCore中,这样基于WebKit的所有移植环境就能方便的使用。同时,该项目未来还将接入更多的WebRTC实现后段,比如等。

这些工作会使苹果公司更容易的在Safari上实现WebRTC功能。

苹果公司做了什么?

WebKit只是一个浏览器引擎,每个使用它的浏览器,都是一个移植版本(port)。webrtcinwebkit项目,最早在WebKit的GTK移植上进行了,在的时候,版浏览器实现了对getUserMedia接口的支持。

针对不同浏览器针对WebRTC协议栈的实现,可以参见这个。作为背景知识,它介绍了不同浏览器如何将WebRTC实现融合到自己的中去。

对于苹果公司,mac平台上的Safari和iOS平台上的Safari是独立的WebKit移植版本。它们没法直接使用之前为GTK移植版本上使用的WebRTC接入代码。因此苹果公司需要单独为这两个移植版本实现WebRTC的接入。

截至8月底,通过的仓库的提交记录的,苹果公司的主要改动有:

  • 针对mac和iOS平台上的改动
    • /platform/mediastream/mac
    • /platform/mac-mavericks/
    • /platform/mac-yosemite/
  • 针对AVFoundation接口的修改(AVVideoCaptureSource.h)
  • 针对苹果平台构建文件的修改(WebCore.xcodeproj/project.pbxproj)

从改动来看,目前苹果已经实现了对GetUserMedia和MediaStream接口在mac和iOS两个平台上的支持。进而支持了对音频、视频设备的列举和选择,支持视频、音频流作为audio和video两个标签的输入来源,支持视频抓取等等功能。

不过,和webrtcinwebkit项目最初实现一样,这些代码改动主要在mac系统移植部分。这是由于WebRTC中的很多功能,涉及到平台相关硬件设备交互、媒体流等需要在标签页之间共享,使得改动主要针对渲染层。

希望这些修改能够让我们能够尽快的在Safari或者iOS的WebView中看见效果。

 

 

 

 

 

 

 

 

 

1,关于openwebrtc

 

OpenWebRTC 是基于 Gstreamer 实现的开源的、跨平台的 WebRTC 客户端框架,支持 H.264 和 VP8。利用 OpenWebRTC,WebRTC就不再仅仅是纯粹浏览器技术了,你可以在NativeAPP中使用WebRTC,并且还可以与浏览器WebRTC互联互通。

这里写图片描述

2,安装服务端demo

demo使用nodejs做服务器。centos安装:

yum install nodejs nodejs-devel
  • 1

下载example代码:

cd /data git clone https://github.com/EricssonResearch/openwebrtc-examples.git cd openwebrtc-examples/web #启动 nohup node channel_server.js & #默认端口8080
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

安装文档参考: 

之后就可以在web进行视频了,使用支出webrtc的浏览器。首先创建房间,然后让另一个客户端,join再call就可以了。

3,android客户端demo

下载最新的android studio,配置好。编译android项目。 

 
项目NativeCall 是客户端sdkdemo。比较粗糙。 
需要注意的是,编译会出警告。增加配置:abortOnError : false

apply plugin: 'com.android.application' android { compileSdkVersion 22 buildToolsVersion "21.1.2" defaultConfig { applicationId "com.ericsson.research.owr.examples.nativecall" minSdkVersion 16 targetSdkVersion 22 versionCode 1 versionName "1.0" ndk { abiFilter "armeabi-v7a" } } // compileOptions { // sourceCompatibility JavaVersion.VERSION_1_7 // targetCompatibility JavaVersion.VERSION_1_7 // } productFlavors { } android { lintOptions { abortOnError false } } } dependencies { // See settings.gradle for local dev instructions // compile project(':openwebrtc-sdk') compile 'io.openwebrtc:openwebrtc-android-sdk:0.1.0' } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35

其中buildToolsVersion 根据自己的版本修改。

修改config配置,进入app再修改也行。假设服务安装在192.168.1.60。

package com.ericsson.research.owr.examples.nativecall; public class Config { /* Changing this does not take effect until app user data is cleared or the app is uninstalled. The server address can be configured inside the application by pressing the icon in the top right. */ //public static final String DEFAULT_SERVER_ADDRESS = "http://demo.openwebrtc.io:38080"; public static final String DEFAULT_SERVER_ADDRESS = "http://192.168.1.60:8080"; public static final String STUN_SERVER = "mmt-stun.verkstad.net"; } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

4,总结

本文的原文连接是:  转载请一定注明出处!

android客户端,可以和web端进行视频,但是好像木有声音,需要再研究下。 

使用openwebrtc可以很简单的搭建web视频聊天。但是需要优化的地方还很多。继续研究。

你可能感兴趣的文章
XenApp_XenDesktop_7.6实战篇之六:DHCP服务器规划及部署
查看>>
监控Web2.0,监控你用户的满意度
查看>>
增强的Java FTP工具----扩展免费版的edtftpj
查看>>
新浪明星日志推荐系统——爬虫爬取数据(2)
查看>>
extjs radio样例集合
查看>>
小议结构体中的大小
查看>>
数据库的唯一标示符(ID)的选择
查看>>
Cocos2d-x 精灵图片预加载中不会出现重复加载问题
查看>>
让UpdatePanel支持文件上传(1):开始
查看>>
活字格企业Web应用生成器V3.0发布更新,支持插件管理和多人协作开发
查看>>
Spring RMI
查看>>
利用vs.net快速开发windows服务(总结)
查看>>
VC 消息映射
查看>>
GO语言练习:组合的用法
查看>>
技术人的生命之源在于绝不固步自封而不断进取的精神
查看>>
Express框架使用以及数据库公共操作类整理(Win7下的NodeJs)
查看>>
kibana智能检索发送多次_msearch —— 配置index pattern,同时设置时间段,就知道到底是在哪些索引里去查找数据了...
查看>>
Linux 小知识翻译 - 「命令行的提示符」
查看>>
Tcp通信
查看>>
【Visual C++】Windows GDI贴图闪烁解决方法
查看>>