一. 编译webrtc
1. 预先准备
1) vpn. 用于同步代码. 这里给一个大概的估计吧. windows端包含vs2013 win8sdk wdk chromium源码等等, 总共需要至少8G. android端还需要android ndk sdk以及大量的依赖库, 大致也是10G往上. 所以需要网速不好的话, 同步一天也是很正常.
2. 同步代码及编译
http://www.webrtc.org/reference/getting-started
参考这个链接, 很详细, 需要认真看.
windows端的配置, 可以参考chromium的windows编译指导, http://dev.chromium.org/developers/how-tos/build-instructions-windows#TOC-Prerequisite-software
工具要求:
tortoisesvn(可选)
msysgit和Tortoisegit(可选)
python(可选)
google的depot_tools会把所有需要的工具全部拉下来并配置好. 所以这些工具都是可选的.
配置depot tools:
svn co http://src.chromium.org/svn/trunk/tools/depot_tools
set path=D:\Libraries\depot_tools;%path% 或 export PATH=/root/depot_tools:$PATH
然后同步webrtc源码: (webrtc_root_dir 是你自己的目录)
cd webrtc_root_dir
gclient config --name src http://webrtc.googlecode.com/svn/trunk
gclient sync --force
gclient runhooks –force
depot_tools 会把vs2013, win8sdk, wdk都下载下来并配置. 在depot_tools/win_toolchain下.
webrtc依赖chromium(源码大小5G左右)
所以总共需要在线下载8G左右.
以后同步代码的时候需要去掉 --force参数. 否则会进行强制重新更新(意味着超长时间-_-!)
生成的工程是webrtcroot/src/all.sln, 编译依赖windows8.1sdk和wdk 可以单独安装, 也可以直接使用depot_tools中的配置.
depot_tools\win_toolchain\vs2013_files\win8sdk 复制到 C:\Program Files (x86)\Windows Kits\8.1
设置环境变量WDK_DIR=depot_tools\win_toolchain\vs2013_files\wdk
遇到的一些问题:
> 打包webrtc工程:
webrtc 与chromium公用很多三方库, 所以目录下会生成很多symlink. 所以不能直接7z或winrar打包, 可以先复制到新目录, 这样symlink会变成空目录. 或者 python src/setup_links.py –c 清除symlink, 然后压缩, 在解压后执行python src/setup_links.py --force 重新生成symlink也可以.
> 强制重新生成vs工程:
set GYP_GENERATORS=msvs
call python src/webrtc/build/gyp_webrtc -G msvs_version=2013
> 如果修改了depot tools的位置:
需要修改\webrtc\trunk\build\win_toolchain.json .
产生systemroot变量未定义错误时. 需要修改F:\depot_tools\win_toolchain\data.json
> gclient sync时, 会报utf8 code error
> 编译时, call python isolate.py 错误.
系统显示语言必须是英文. 从来没见过像google这么傻逼的.
>svn too old
把更新depot_tools时用的svn(或者高版本svn)替换depot_tools/svn_bin.
> error LNK2019: unresolved external symbol _intel_aes_encrypt_init_128 referenced in function _aes_InitContext
在trunk\third_party\nss\nss.gyp目录中注释掉USE_HW_AES和INTEL_GCM, 需要在重新生成工程文件.
或者直接删除nss_*.vcprojx中USE_HW_AES和INTEL_GCM的define.
>warning treated as error no object file generated
原因是该文件的代码页为英文,而我们系统中的代码页为中文
解决方法: 1. region->administrative->language for non-unicode programs的语言改成english.
2. 在编译开关里拿掉 /WX 开关, 即warning level. 可能会涉及很多工程.
vcxproj中是<TreatWarningAsError>true</TreatWarningAsError>
>bash:../../third_party/libvpx/copy_obj.sh: /bin/bash: bad interpreter: No such file or directory
可以使用源代码下的E:\chromium\src\third_party\cygwin\setup_mount.bat,解决 ,双击此文件即可。执行完后,清理工程,再次编译,如果出现如下问题: >copy_obj.sh: line 6: $'\r': command not found
可以使用UltraEdit ->“文件”->“转换”->“Dos转Unix” (编辑copy_obj.sh文件),“保存”,再次清理工程,然后编译,(其实上面的问题都是因为不同操作系统下,文件的中回车/换行标示方法引起的,找个工具转换下就ok了)
>atls.lib(atlbase.obj) : error LNK2005: "class ATL::CAtlWinModule ATL::_AtlWinModule" (?_AtlWinModule@ATL@@3VCAtlWinModule@1@A) already defined in libjingle_media.lib(win32devicemanager.obj)
add "/FORCE:MULTIPLE" in Linker-->CommandLine.
另一种解决办法是, 把\depot_tools\win_toolchain\vs2013_files\wdk\lib\Atl\i386下的atls.lib删掉或重命名. 这样就会链接到C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\atlmfc\lib\atls.lib, 重定义就解决了. 这个因为是因为vs2013 update的原因.
linux 及android端:
google 默认的android 编译环境是ubuntu 64位. 其他环境需要自己测试.
本人使用ubuntu 14.01lts 64bit.
与windows类似, 需要depot tools. 然后配置环境变量 export PATH=/home/ldh/depot_tools:$PATH
配置JDK:
使用的是oracle jdk 1.7. 低于1.7会导致编译错误.
export JAVA_HOME=/home/ldh/jdk1.6.0_45
export PATH=$JAVA_HOME/bin:$PATH
linux:
./build/install-build-deps.sh #linux需要依赖 gclient sync
linux下默认使用ninja, 如果需要使用make的话, 指定 export GYP_GENERATORS=make
android只支持ninja编译
android同步代码
./build/install-build-deps-android.sh #android需要的依赖
$ echo "target_os = ['android', 'unix']" >> .gclient
$ gclient sync
$ cd src
$ source ./build/android/envsetup.sh
$ export GYP_DEFINES="$GYP_DEFINES OS=android"
编译:
$ cd src
Debug:
$ ninja -C out/Debug
Release:
$ ninja -C out/Release
错误
util.build_utils.CalledProcessError: Command failed: ( cd /home/ldh/webrtc/src/chromium/src/build/android; javac -g -source 1.7 -target 1.7
javac: invalid source release: 1.7
jdk版本错误, 需要jdk1.7
gclient同步时出现git fatal error out of memory 时
git gc --aggressive --prune=now
git repack -a -d --depth=250 --window=250
这两条命令也可以用户减少.git文件夹的大小.
二. webrtc demo 简介
windows 下. peerconnection_client 和 peerconnection_server 可以直接测试. server可以部署在公网上.
android下. talk/examples/android 是apprtc的工程(最新名字是ConnectActivity.apk). 使用apprtc.appspot.com作为signal服务器. 可以测试android app, 也可以测试chrome网页.