開發者工具|15款音視訊開發者必備實用工具,看看你用過幾個?
本文正在參加「金石計劃 . 瓜分6萬現金大獎」https://juejin.cn/post/7162096952883019783
對於音視訊開發者來說,有個高效的輔助工具能大大提升開發效率。今天博主推薦這些年來桌面必備的工具,如果您覺得對你有用,可以收藏防止下次找不到。
🔨 推薦1 Ghips
📌 一句話描述 :僅
600KB
的開源軟體,通過GitHub官方API獲取所有IP,並自動找到最快IP。
👀 開源地址
https://github.com/aardio/Ghips
⚓️ 下載連結
https://github.com/aardio/Ghips/releases/latest/download/Ghips.7z
🎯 功能介紹
Ghips
通過GitHub
官方API獲取所有IP
,並自動找到最快IP
。將得到的最快IP寫入到本地hosts
。
注意:更新
IP
後首次訪問GitHub
會比較慢,稍等就快了。
--------------------------------
🔨 推薦2 ScreenToGif
📌 一句話描述 :提供錄屏轉
gif
、gif
編輯、視訊轉gif
等功能。
👀 開源地址
https://github.com/NickeManarin/ScreenToGif
⚓️ 下載連結
https://github.com/NickeManarin/ScreenToGif/releases
🎯 功能介紹
主要包含4個主要入口:
- 錄影機:用於錄屏製作gif或視訊
- 攝像頭:實時採集攝像頭資料製作gif或視訊
- 畫板:提供白板,實時記錄畫筆繪製畫面,儲存為gif或視訊
- 編輯器:編輯視訊或gif,可以將視訊或gif相互轉換
對於錄製視訊,ScreenToGif
可選定螢幕區域執行錄屏,並可設定fps
,如下圖所示。
對選定的視訊
、gif
或錄製好的內容
,包含如下所示的編輯功能
📢推薦總結:凡是涉及到gif相關的工作,強烈推薦Screen2Gif工具
--------------------------------
🔨 推薦3 螢幕拾色器
📌 一句話描述 :ColorPicker是一款基於MFC實現的螢幕拾色器。
👀 開源地址
https://github.com/hufuman/colorpicker
⚓️ 下載連結
https://raw.githubusercontent.com/hufuman/colorpicker/master/ColorPicker.exe
🎯 功能介紹
滑鼠所移之處實時顯示RGB值,當確定選取當前位置的畫素值時,按快捷鍵:ctrl + 1
。
--------------------------------
🔨 推薦4 OBS Studio
📌 一句話描述 :對個人電腦配置要求低,只需推流地址即可實現螢幕內容錄製並推流直播。
👀 開源地址
https://github.com/obsproject/obs-studio?source=juejin&article56
⚓️ 下載連結
https://obsproject.com/?source=juejin&article56
🎯 功能介紹
OBS Studio是一款免費開源的螢幕錄製和實時流媒體軟體,支援Windows、Linux和Mac作業系統。對資源佔用較少,配置要求底。只需要有推流地址比如抖音推流地址,即可完成螢幕實時錄製推流到抖音直播。
對於直播開發者來說,OBS是一款不錯的測試客戶端。
--------------------------------
🔨 推薦5 ffmpeg
📌 一句話描述 :FFmpeg是可以用於音訊、視訊、影象格式轉換、編解碼、切換壓縮演算法等非常強大的工具。
👀 開源地址
https://github.com/FFmpeg/FFmpeg
⚓️ 下載連結
https://github.com/FFmpeg/FFmpeg/releases
🎯 功能介紹
毫不誇張地說,市面上80%以上視訊處理類的軟體(或App)底層都用到了ffmpeg庫。對於ffmpeg庫,底層通過C++直接呼叫;對於非開發者而言,可以直接呼叫官方編譯好的工具通過命令列呼叫。
- 圖片方面,圖片格式轉換,圖片轉視訊等。
- 視訊採集方面,ffmpeg可以設定幀率(fps),編解碼演算法(h264,h265等),設定位元速率(bps)等。
- 視訊格式方面,ffmpeg可以實現多種視訊格式之間的相互轉換(wma,rm,avi,mod等)。
- 直播方面,ffmpeg可以推流直播。
--------------------------------
🔨 推薦6 Image Watch
📌 一句話描述 :Opencv官方出品的VisualStudio外掛,它可以讓開發者在除錯一個OpenCV程式時,直觀地看到記憶體中的影象,並能直接在除錯介面中做一系列的影象操作。
⚓️ 獲取方式
VisualStudio選單 -> 工具 -> 擴充套件和更新(U)... -> 聯機 -> 在右上角的搜尋欄中直接搜尋Image Watch -> 在搜尋的結果點選下載即可。
🎯 功能介紹
在需要視覺化的Mat物件後面加一個斷點,觸發斷點後,在ImageWatch介面中會列出當前上下文中的所有Mat物件,點選Mat物件即可顯示對應的圖片,並且放大後可以看到具體的畫素值。
--------------------------------
🔨 推薦7 Open Image Debugger
📌 一句話描述 :Open Image Debugger用於在除錯期間視覺化記憶體圖片,與Image Watch功能類似,不過Open Image Debugger更多聚焦在Linux和Mac系統上。
👀 開源地址
https://github.com/OpenImageDebugger/OpenImageDebugger
⚓️ 下載連結
https://github.com/OpenImageDebugger/OpenImageDebugger/releases/tag/v1.3.0
🎯 功能介紹 Open Image Debugger用於在除錯期間視覺化記憶體圖片, 圖片物件可以為Opencv的Mat以及Eigen的matrices,相容GDB和LLDB。主要包含以下特性:
- GUI互動:
- 滾輪放縮,拖拽移動快取區
- 對快取區順時針或逆時針旋轉90度
- 跳轉到任意畫素位置
- 快取值:放大到極限後,顯示對應的畫素數值。
- 自動更新:快取檢視會自動更新內容。
- 自動對比度:緩衝區中的整個值範圍可以自動對映到視覺化範圍[0,1],其中0表示黑色,1表示白色。
- 對比度範圍可以手動調整,這對於檢查具有極值(例如無窮大、nan和其他異常值)的緩衝區非常有用。
- 檢視連結在一起,在螢幕上移動任何單個緩衝區時同時移動所有關注的緩衝區。
- 支援的緩衝區型別:uint8_t,int16_t,uint16_t、int32_t、uint32_t,float和double
- 支援的緩衝通道:最多四個通道(灰度、兩個通道、RGB和RGBA)
- 支援GPU加速
📢推薦總結:對於使用QT Creator的應用,Open Image Debugger除錯OpenCV還是非常有用的。
--------------------------------
🔨 推薦8 OpenCV
📌 一句話描述 :大名鼎鼎的Opencv,提供了彙編級優化過的影象處理演算法集。
👀 開源地址
https://github.com/opencv/opencv
⚓️ 官方網站
🎯 功能介紹
OpenCV
基於C++
實現,但提供了Python
、Java
、Matlab
等介面,並支援Windows
、Linux
、Mac
、Android
以及iOS
等主流作業系統。在影象處理、影象分類、目標檢測、影象分割、風格遷移、影象重構、超解析度、影象生成、人臉識別等CV
領域都有廣泛的使用。
簡單來說,Photoshop
裡面用到的功能都可以通過OpenCV
來實現, 就問你它強不強!
--------------------------------
🔨 推薦9 SRS(Simple Realtime Server)
📌 一句話描述 :一款簡單、高效的實時視訊伺服器。
👀 開源地址
⚓️ 下載連結
https://github.com/ossrs/srs/releases
🎯 功能介紹
SRS(Simple Realtime Server)
是一個簡單高效的實時視訊伺服器,支援 RTMP
/WebRTC
/HLS
/HTTP-FLV
/SRT
/GB28181
,它是高效能的流媒體伺服器。可以用來構建直播和視訊會議的後端服務。SRS
專案的目標是降低(不能消除)音視訊的門檻。
核心功能,如下:
更多技術細節可以參考官方文件:https://ossrs.net/lts/zh-cn/docs/v4/doc/getting-started
🔨 推薦10 免費額度大的第三方實時音視訊SDK
對於新手來說,音視訊的門檻真的非常高。前面也說了音視訊開發門檻是無法消除的,最快的方式是藉助第三方搭建好的實時音視訊平臺。市面上有很多,這裡我簡單介紹一下平時用的多的【即構平臺】。
📌 一句話描述 :免費額度大,整體價效比高,適合個人開發者快速搭建一個帶有實時視訊或直播的App。
⚓️ 官方網址
🎯 功能介紹
- 實時音視訊, 可實現多人聊天室
- 即時通訊,可實現聊天App
- 元宇宙,捏臉,虛擬形象聊天
--------------------------------
🔨 推薦11 wireshark
📌 一句話描述 :是一個網路封包分析軟體,可以分析網路實時收發資料包。
👀 開源地址 https://github.com/wireshark/wireshark
⚓️ 下載連結 https://www.wireshark.org/#download
🎯 功能介紹
- 支援分析數百種網路協議,並實時更新最新的新協議。
- 支援線上抓包,離線分析。
- 支援主流作業系統平臺。
- 支援豐富且強大的包過濾語法
- 支援讀取分析多種檔案格式:
tcpdump
(libpcap
),Pcap NG
等。 - 支援抓取多種物理介面:
Ethernet
,IEEE 802.11
,PPP/HDLC
,ATM
,Bluetooth
,USB
等。 - 支援分析解密多種安全協議:
IPsec
,ISAKMP
,Kerberos
,SNMPv3
,SSL/TLS
,WEP
,WPA/WPA2
等。
--------------------------------
🔨 推薦12 mitmproxy
📌 一句話描述 :為滲透測試人員和軟體開發人員提供的互動式TLS攔截HTTP代理。
👀 開源地址
https://github.com/mitmproxy/mitmproxy
⚓️ 官方網站
🎯 功能介紹
- mitm提供了命令列、Web介面、Python庫三種使用方式。
-
命令列如下所示。
-
Web介面如下所示。
- Python庫, python呼叫方式如下: ```python from mitmproxy import http
def request(flow: http.HTTPFlow): # redirect to different host if flow.request.pretty_host == "example.com": flow.request.host = "mitmproxy.org" # answer from proxy elif flow.request.path.endswith("/brew"): flow.response = http.Response.make( 418, b"I'm a teapot", ) ```
--------------------------------
🔨 推薦13 protobuf
📌 一句話描述 :通過將結構化的資料進行序列化(序列化),用於通訊協議、資料儲存等領域的語言無關、平臺無關、可擴充套件的序列化結構資料格式。
👀 開源地址
https://github.com/protocolbuffers/protobuf
⚓️ 下載連結
https://github.com/protocolbuffers/protobuf/releases
🎯 功能介紹
- 一種二進位制資料交換格式。可以將
C++
中定義的儲存類的內容與二進位制序列串相互轉換,主要用於資料傳輸或儲存 - 定義了一種原始檔,副檔名為
.proto
(類比.cpp
檔案),使用這種原始檔,可以定義儲存類的內容 protobuf
有自己的編譯器protoc
,可以將.proto
編譯指定語言原始碼,如.cc
、.py
、.js
等主流程式語言原始碼。
--------------------------------
🔨 推薦14 protobuf inspector
📌 一句話描述 :對未知結構的
Protocol Buffer
資料逆向並可視化結構。
👀 開源地址
https://github.com/mildsunrise/protobuf-inspector
⚓️ 安裝使用
pip install protobuf-inspector
🎯 功能介紹
- 安裝庫
pip install protobuf-inspector
- 安裝完後可以直接使用命令列
protobuf_inspector < my-protobuf-blob
,其中my-protobuf-blob
是未知的pb
資料包。 - 示例如下:
shell $ protobuf_inspector < my-blob root: 1 <varint> = 1469046243471 2 <chunk> = "kotlin46" 7 <chunk> = bytes (5) 0000 00 01 03 04 07 ..... 8 <chunk> = empty chunk 9 <varint> = 250 10 <32bit> = 0x43480000 / 1128792064 / 200.000 14 <chunk> = message: 1 <chunk> = "POKECOIN" 14 <chunk> = message: 1 <chunk> = "STARDUST" 2 <varint> = 100
--------------------------------
🔨 推薦15 PPOCR
📌 一句話描述 :非常小的OCR模型,可以用於日常圖片中文字提取。
👀 開源地址 https://github.com/PaddlePaddle/PaddleOCR
⚓️ 官方教程
https://github.com/PaddlePaddle/PaddleOCR/blob/release/2.5/README_ch.md
🎯 功能介紹
1. 線上網站體驗:超輕量PP-OCR mobile
模型體驗地址:https://www.paddlepaddle.org.cn/hub/scene/ocr
2. 移動端demo
體驗:安裝包DEMO
下載地址(基於EasyEdge和Paddle-Lite, 支援iOS和Android系統)
3. 一行命令快速使用:快速開始(中英文/多語言/文件分析)