mirror of
https://github.com/kunkundi/crossdesk.git
synced 2025-10-27 04:35:34 +08:00
Update x11 capture module
This commit is contained in:
@@ -4,3 +4,8 @@ vcpkg/buildtrees/versioning_/versions/pcre/69e232f12c4e3eab4115f0672466a6661978b
|
|||||||
|
|
||||||
- URLS "https://ftp.pcre.org/pub/pcre/pcre-${PCRE_VERSION}.zip"
|
- URLS "https://ftp.pcre.org/pub/pcre/pcre-${PCRE_VERSION}.zip"
|
||||||
+ URLS "https://sourceforge.net/projects/pcre/files/pcre/${PCRE_VERSION}/pcre-${PCRE_VERSION}.zip"
|
+ URLS "https://sourceforge.net/projects/pcre/files/pcre/${PCRE_VERSION}/pcre-${PCRE_VERSION}.zip"
|
||||||
|
|
||||||
|
linux
|
||||||
|
|
||||||
|
apt-get install nvidia-cuda-toolkit
|
||||||
|
solve <cuda.h>
|
||||||
@@ -26,6 +26,9 @@
|
|||||||
#include <thread>
|
#include <thread>
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
#include <libavcodec/avcodec.h>
|
||||||
|
#include <libavdevice/avdevice.h>
|
||||||
|
#include <libavfilter/avfilter.h>
|
||||||
#include <libavformat/avformat.h>
|
#include <libavformat/avformat.h>
|
||||||
#include <libavutil/imgutils.h>
|
#include <libavutil/imgutils.h>
|
||||||
#include <libswscale/swscale.h>
|
#include <libswscale/swscale.h>
|
||||||
@@ -35,7 +38,11 @@ extern "C" {
|
|||||||
#include "imgui_impl_sdl2.h"
|
#include "imgui_impl_sdl2.h"
|
||||||
#include "imgui_impl_sdlrenderer2.h"
|
#include "imgui_impl_sdlrenderer2.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
#ifdef _WIN32
|
||||||
#include "screen_capture_wgc.h"
|
#include "screen_capture_wgc.h"
|
||||||
|
#elif __linux__
|
||||||
|
#include "screen_capture_x11.h"
|
||||||
|
#endif
|
||||||
#include "x.h"
|
#include "x.h"
|
||||||
|
|
||||||
#define NV12_BUFFER_SIZE 1280 * 720 * 3 / 2
|
#define NV12_BUFFER_SIZE 1280 * 720 * 3 / 2
|
||||||
@@ -74,10 +81,14 @@ bool received_frame = false;
|
|||||||
static bool connect_button_pressed = false;
|
static bool connect_button_pressed = false;
|
||||||
static const char *connect_label = "Connect";
|
static const char *connect_label = "Connect";
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
ScreenCaptureWgc *screen_capture = nullptr;
|
ScreenCaptureWgc *screen_capture = nullptr;
|
||||||
|
#elif __linux__
|
||||||
|
ScreenCaptureX11 *screen_capture = nullptr;
|
||||||
|
#endif
|
||||||
|
|
||||||
char *nv12_buffer_ = nullptr;
|
char *nv12_buffer = nullptr;
|
||||||
std::chrono::steady_clock::time_point last_frame_time_;
|
std::chrono::_V2::system_clock::time_point last_frame_time_;
|
||||||
|
|
||||||
typedef enum { mouse = 0, keyboard } ControlType;
|
typedef enum { mouse = 0, keyboard } ControlType;
|
||||||
typedef enum { move = 0, left_down, left_up, right_down, right_up } MouseFlag;
|
typedef enum { move = 0, left_down, left_up, right_down, right_up } MouseFlag;
|
||||||
@@ -527,7 +538,7 @@ int main() {
|
|||||||
if (strcmp(online_label, "Online") == 0) {
|
if (strcmp(online_label, "Online") == 0) {
|
||||||
CreateConnection(peer_server, mac_addr, server_password);
|
CreateConnection(peer_server, mac_addr, server_password);
|
||||||
|
|
||||||
nv12_buffer_ = new char[NV12_BUFFER_SIZE];
|
nv12_buffer = new char[NV12_BUFFER_SIZE];
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
screen_capture = new ScreenCaptureWgc();
|
screen_capture = new ScreenCaptureWgc();
|
||||||
|
|
||||||
@@ -549,9 +560,38 @@ int main() {
|
|||||||
|
|
||||||
if (tc >= 0) {
|
if (tc >= 0) {
|
||||||
BGRAToNV12FFmpeg(data, width, height,
|
BGRAToNV12FFmpeg(data, width, height,
|
||||||
(unsigned char *)nv12_buffer_);
|
(unsigned char *)nv12_buffer);
|
||||||
SendData(peer_server, DATA_TYPE::VIDEO,
|
SendData(peer_server, DATA_TYPE::VIDEO,
|
||||||
(const char *)nv12_buffer_, NV12_BUFFER_SIZE);
|
(const char *)nv12_buffer, NV12_BUFFER_SIZE);
|
||||||
|
// std::cout << "Send" << std::endl;
|
||||||
|
last_frame_time_ = now_time;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
screen_capture->Start();
|
||||||
|
|
||||||
|
#elif __linux__
|
||||||
|
screen_capture = new ScreenCaptureX11();
|
||||||
|
|
||||||
|
RECORD_DESKTOP_RECT rect;
|
||||||
|
rect.left = 0;
|
||||||
|
rect.top = 0;
|
||||||
|
rect.right = 0;
|
||||||
|
rect.bottom = 0;
|
||||||
|
|
||||||
|
last_frame_time_ = std::chrono::high_resolution_clock::now();
|
||||||
|
screen_capture->Init(
|
||||||
|
rect, 60,
|
||||||
|
[](unsigned char *data, int size, int width,
|
||||||
|
int height) -> void {
|
||||||
|
auto now_time = std::chrono::high_resolution_clock::now();
|
||||||
|
std::chrono::duration<double> duration =
|
||||||
|
now_time - last_frame_time_;
|
||||||
|
auto tc = duration.count() * 1000;
|
||||||
|
|
||||||
|
if (tc >= 0) {
|
||||||
|
SendData(peer_server, DATA_TYPE::VIDEO,
|
||||||
|
(const char *)nv12_buffer, NV12_BUFFER_SIZE);
|
||||||
// std::cout << "Send" << std::endl;
|
// std::cout << "Send" << std::endl;
|
||||||
last_frame_time_ = now_time;
|
last_frame_time_ = now_time;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,16 +11,20 @@ ScreenCaptureX11::~ScreenCaptureX11() {}
|
|||||||
|
|
||||||
int ScreenCaptureX11::Init(const RECORD_DESKTOP_RECT &rect, const int fps,
|
int ScreenCaptureX11::Init(const RECORD_DESKTOP_RECT &rect, const int fps,
|
||||||
cb_desktop_data cb) {
|
cb_desktop_data cb) {
|
||||||
|
if (cb) {
|
||||||
|
_on_data = cb;
|
||||||
|
}
|
||||||
|
|
||||||
pFormatCtx_ = avformat_alloc_context();
|
pFormatCtx_ = avformat_alloc_context();
|
||||||
|
|
||||||
avdevice_register_all();
|
avdevice_register_all();
|
||||||
|
|
||||||
// grabbing frame rate
|
// grabbing frame rate
|
||||||
av_dict_set(&options_, "framerate", "5", 0);
|
av_dict_set(&options_, "framerate", "30", 0);
|
||||||
// Make the grabbed area follow the mouse
|
// Make the grabbed area follow the mouse
|
||||||
av_dict_set(&options_, "follow_mouse", "centered", 0);
|
av_dict_set(&options_, "follow_mouse", "centered", 0);
|
||||||
// Video frame size. The default is to capture the full screen
|
// Video frame size. The default is to capture the full screen
|
||||||
av_dict_set(&options_, "video_size", "1280x720", 0);
|
// av_dict_set(&options_, "video_size", "1280x720", 0);
|
||||||
ifmt_ = (AVInputFormat *)av_find_input_format("x11grab");
|
ifmt_ = (AVInputFormat *)av_find_input_format("x11grab");
|
||||||
if (!ifmt_) {
|
if (!ifmt_) {
|
||||||
printf("Couldn't find_input_format\n");
|
printf("Couldn't find_input_format\n");
|
||||||
@@ -103,6 +107,10 @@ int ScreenCaptureX11::Start() {
|
|||||||
sws_scale(img_convert_ctx_, pFrame_->data, pFrame_->linesize, 0,
|
sws_scale(img_convert_ctx_, pFrame_->data, pFrame_->linesize, 0,
|
||||||
pFrame_->height, pFrameNV12_->data,
|
pFrame_->height, pFrameNV12_->data,
|
||||||
pFrameNV12_->linesize);
|
pFrameNV12_->linesize);
|
||||||
|
|
||||||
|
_on_data((unsigned char *)nv12_buffer_,
|
||||||
|
pFrame_->width * pFrame_->height * 3 / 2, pFrame_->width,
|
||||||
|
pFrame_->height);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -38,14 +38,12 @@ int X11SessionImpl::Start() {
|
|||||||
|
|
||||||
int X11SessionImpl::Stop() { return 0; }
|
int X11SessionImpl::Stop() { return 0; }
|
||||||
|
|
||||||
int X11SessionImpl::Pause() {}
|
int X11SessionImpl::Pause() { return 0; }
|
||||||
|
|
||||||
int X11SessionImpl::Resume() {}
|
int X11SessionImpl::Resume() { return 0; }
|
||||||
|
|
||||||
void X11SessionImpl::OnFrame() {}
|
void X11SessionImpl::OnFrame() {}
|
||||||
|
|
||||||
void X11SessionImpl::OnClosed() {}
|
void X11SessionImpl::OnClosed() {}
|
||||||
|
|
||||||
int X11SessionImpl::Initialize() { return 0; }
|
|
||||||
|
|
||||||
void X11SessionImpl::CleanUp() {}
|
void X11SessionImpl::CleanUp() {}
|
||||||
@@ -28,7 +28,6 @@ class X11SessionImpl : public X11Session {
|
|||||||
void OnFrame();
|
void OnFrame();
|
||||||
void OnClosed();
|
void OnClosed();
|
||||||
|
|
||||||
int Initialize();
|
|
||||||
void CleanUp();
|
void CleanUp();
|
||||||
|
|
||||||
// void message_func();
|
// void message_func();
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ target("log")
|
|||||||
|
|
||||||
target("screen_capture")
|
target("screen_capture")
|
||||||
set_kind("static")
|
set_kind("static")
|
||||||
add_packages("log")
|
add_packages("log", "ffmpeg")
|
||||||
if is_os("windows") then
|
if is_os("windows") then
|
||||||
add_files("screen_capture/windows/*.cpp")
|
add_files("screen_capture/windows/*.cpp")
|
||||||
add_includedirs("screen_capture/windows", {public = true})
|
add_includedirs("screen_capture/windows", {public = true})
|
||||||
@@ -63,4 +63,9 @@ target("remote_desk")
|
|||||||
add_links("SDL2")
|
add_links("SDL2")
|
||||||
elseif is_os("linux") then
|
elseif is_os("linux") then
|
||||||
add_links("SDL2")
|
add_links("SDL2")
|
||||||
|
-- add_ldflags("-lsndio", "-lasound", "-lxcb", "-lX11", "-lXext", "-lXv",
|
||||||
|
-- "-lxcb-shape", "-lxcb-xfixes", "-lxcb-shm", "-lavfilter", "-ldl",
|
||||||
|
-- "-lavdevice", "-lavformat", "-lavcodec", "-lswscale", "-lswresample",
|
||||||
|
-- "-lavutil", {force = true})
|
||||||
|
-- -- add_ldflags("-lasound", "-lX11", "-lXext", "-lxcb", "-lsndio", "-lpostproc", "-ldl", {force = true})
|
||||||
end
|
end
|
||||||
@@ -29,6 +29,8 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <chrono>
|
||||||
|
|
||||||
// Output YUV420P
|
// Output YUV420P
|
||||||
#define OUTPUT_YUV420P 0
|
#define OUTPUT_YUV420P 0
|
||||||
//'1' Use Dshow
|
//'1' Use Dshow
|
||||||
@@ -47,6 +49,10 @@ SDL_Texture *sdlTexture = nullptr;
|
|||||||
SDL_Renderer *sdlRenderer = nullptr;
|
SDL_Renderer *sdlRenderer = nullptr;
|
||||||
SDL_Rect sdlRect;
|
SDL_Rect sdlRect;
|
||||||
unsigned char nv12_buffer[NV12_BUFFER_SIZE];
|
unsigned char nv12_buffer[NV12_BUFFER_SIZE];
|
||||||
|
std::chrono::_V2::system_clock::time_point last_frame_time;
|
||||||
|
const int pixel_w = 1280, pixel_h = 720;
|
||||||
|
int screen_w = 1280, screen_h = 720;
|
||||||
|
bool done = false;
|
||||||
|
|
||||||
int YUV420ToNV12FFmpeg(unsigned char *src_buffer, int width, int height,
|
int YUV420ToNV12FFmpeg(unsigned char *src_buffer, int width, int height,
|
||||||
unsigned char *des_buffer) {
|
unsigned char *des_buffer) {
|
||||||
@@ -78,7 +84,7 @@ int sfp_refresh_thread(void *opaque) {
|
|||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
event.type = SFM_REFRESH_EVENT;
|
event.type = SFM_REFRESH_EVENT;
|
||||||
SDL_PushEvent(&event);
|
SDL_PushEvent(&event);
|
||||||
SDL_Delay(40);
|
SDL_Delay(30);
|
||||||
printf("sfp_refresh_thread\n");
|
printf("sfp_refresh_thread\n");
|
||||||
}
|
}
|
||||||
thread_exit = 0;
|
thread_exit = 0;
|
||||||
@@ -113,7 +119,7 @@ int main(int argc, char *argv[]) {
|
|||||||
AVDictionary *options = NULL;
|
AVDictionary *options = NULL;
|
||||||
// Set some options
|
// Set some options
|
||||||
// grabbing frame rate
|
// grabbing frame rate
|
||||||
av_dict_set(&options, "framerate", "5", 0);
|
av_dict_set(&options, "framerate", "30", 0);
|
||||||
// Make the grabbed area follow the mouse
|
// Make the grabbed area follow the mouse
|
||||||
av_dict_set(&options, "follow_mouse", "centered", 0);
|
av_dict_set(&options, "follow_mouse", "centered", 0);
|
||||||
// Video frame size. The default is to capture the full screen
|
// Video frame size. The default is to capture the full screen
|
||||||
@@ -173,8 +179,7 @@ int main(int argc, char *argv[]) {
|
|||||||
printf("Could not initialize SDL - %s\n", SDL_GetError());
|
printf("Could not initialize SDL - %s\n", SDL_GetError());
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
const int pixel_w = 1280, pixel_h = 720;
|
|
||||||
int screen_w = 1280, screen_h = 720;
|
|
||||||
// const SDL_VideoInfo *vi = SDL_GetVideoInfo();
|
// const SDL_VideoInfo *vi = SDL_GetVideoInfo();
|
||||||
// Half of the Desktop's width and height.
|
// Half of the Desktop's width and height.
|
||||||
screen_w = 1280;
|
screen_w = 1280;
|
||||||
@@ -223,34 +228,32 @@ int main(int argc, char *argv[]) {
|
|||||||
// SDL_WM_SetCaption("Simplest FFmpeg Grab Desktop", NULL);
|
// SDL_WM_SetCaption("Simplest FFmpeg Grab Desktop", NULL);
|
||||||
// Event Loop
|
// Event Loop
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
printf("111111111\n");
|
|
||||||
|
last_frame_time = std::chrono::high_resolution_clock::now();
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
// Wait
|
// Wait
|
||||||
SDL_WaitEvent(&event);
|
SDL_WaitEvent(&event);
|
||||||
printf("11112222\n");
|
|
||||||
if (event.type == SFM_REFRESH_EVENT) {
|
if (1) {
|
||||||
printf("11111113333333\n");
|
|
||||||
//------------------------------
|
//------------------------------
|
||||||
if (av_read_frame(pFormatCtx, packet) >= 0) {
|
if (av_read_frame(pFormatCtx, packet) >= 0) {
|
||||||
printf("111111444444\n");
|
|
||||||
if (packet->stream_index == videoindex) {
|
if (packet->stream_index == videoindex) {
|
||||||
printf("11111155555\n");
|
|
||||||
avcodec_send_packet(pCodecCtx, packet);
|
avcodec_send_packet(pCodecCtx, packet);
|
||||||
got_picture = avcodec_receive_frame(pCodecCtx, pFrame);
|
got_picture = avcodec_receive_frame(pCodecCtx, pFrame);
|
||||||
printf("33333333\n");
|
|
||||||
// ret = avcodec_decode_video2(pCodecCtx, pFrame, &got_picture,
|
// ret = avcodec_decode_video2(pCodecCtx, pFrame, &got_picture,
|
||||||
// packet);
|
// packet);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
printf("Decode Error.\n");
|
printf("Decode Error.\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
printf("xxxxxxxxxxxxxxxxxxx\n");
|
||||||
if (!got_picture) {
|
if (!got_picture) {
|
||||||
printf("44444444444\n");
|
auto now_time = std::chrono::high_resolution_clock::now();
|
||||||
|
std::chrono::duration<double> duration = now_time - last_frame_time;
|
||||||
// memcpy(nv12_buffer, pFrame->data[0],
|
auto tc = duration.count() * 1000;
|
||||||
// pFrame->width * pFrame->height);
|
printf("duration: %f\n", tc);
|
||||||
// memcpy(nv12_buffer + pFrame->width * pFrame->height,
|
last_frame_time = now_time;
|
||||||
// pFrame->data[1], pFrame->width * pFrame->height / 2);
|
|
||||||
|
|
||||||
av_image_fill_arrays(pFrameNV12->data, pFrameNV12->linesize,
|
av_image_fill_arrays(pFrameNV12->data, pFrameNV12->linesize,
|
||||||
nv12_buffer, AV_PIX_FMT_NV12, pFrame->width,
|
nv12_buffer, AV_PIX_FMT_NV12, pFrame->width,
|
||||||
@@ -291,7 +294,7 @@ int main(int argc, char *argv[]) {
|
|||||||
#if OUTPUT_YUV420P
|
#if OUTPUT_YUV420P
|
||||||
fclose(fp_yuv);
|
fclose(fp_yuv);
|
||||||
#endif
|
#endif
|
||||||
printf("222222222\n");
|
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
|
|
||||||
// av_free(out_buffer);
|
// av_free(out_buffer);
|
||||||
|
|||||||
39
xmake.lua
39
xmake.lua
@@ -7,23 +7,6 @@ set_languages("c++17")
|
|||||||
|
|
||||||
add_rules("mode.release", "mode.debug")
|
add_rules("mode.release", "mode.debug")
|
||||||
|
|
||||||
add_requires("asio 1.24.0", "nlohmann_json", "spdlog 1.11.0")
|
|
||||||
|
|
||||||
if is_os("windows") then
|
|
||||||
add_requires("vcpkg::ffmpeg 5.1.2", {configs = {shared = false}})
|
|
||||||
add_packages("vcpkg::ffmpeg")
|
|
||||||
add_requires("vcpkg::libnice 0.1.21")
|
|
||||||
add_packages("vcpkg::libnice")
|
|
||||||
elseif is_os("linux") then
|
|
||||||
add_requires("vcpkg::ffmpeg", {configs = {shared = false}})
|
|
||||||
add_requires("glib", {system = true})
|
|
||||||
add_requires("vcpkg::libnice 0.1.21")
|
|
||||||
add_packages("ffmpeg", "glib", "vcpkg::libnice")
|
|
||||||
elseif is_os("macosx") then
|
|
||||||
add_requires("ffmpeg 5.1.2", {system = false})
|
|
||||||
add_requires("brew::libnice", "brew::glib")
|
|
||||||
end
|
|
||||||
|
|
||||||
add_defines("ASIO_STANDALONE", "ASIO_HAS_STD_TYPE_TRAITS", "ASIO_HAS_STD_SHARED_PTR",
|
add_defines("ASIO_STANDALONE", "ASIO_HAS_STD_TYPE_TRAITS", "ASIO_HAS_STD_SHARED_PTR",
|
||||||
"ASIO_HAS_STD_ADDRESSOF", "ASIO_HAS_STD_ATOMIC", "ASIO_HAS_STD_CHRONO", "ASIO_HAS_CSTDINT", "ASIO_HAS_STD_ARRAY",
|
"ASIO_HAS_STD_ADDRESSOF", "ASIO_HAS_STD_ATOMIC", "ASIO_HAS_STD_CHRONO", "ASIO_HAS_CSTDINT", "ASIO_HAS_STD_ARRAY",
|
||||||
"ASIO_HAS_STD_SYSTEM_ERROR")
|
"ASIO_HAS_STD_SYSTEM_ERROR")
|
||||||
@@ -40,6 +23,22 @@ elseif is_os("macosx") then
|
|||||||
add_ldflags("-ld_classic", {force = true})
|
add_ldflags("-ld_classic", {force = true})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
add_requires("asio 1.24.0", "nlohmann_json", "spdlog 1.11.0")
|
||||||
|
|
||||||
|
if is_os("windows") then
|
||||||
|
add_requires("vcpkg::ffmpeg 5.1.2", {configs = {shared = false}})
|
||||||
|
add_requires("vcpkg::libnice 0.1.21")
|
||||||
|
add_packages("vcpkg::libnice")
|
||||||
|
elseif is_os("linux") then
|
||||||
|
add_requires("ffmpeg 5.1.2", {shared = true})
|
||||||
|
add_requires("glib", {system = true})
|
||||||
|
add_requires("vcpkg::libnice 0.1.21")
|
||||||
|
add_packages("glib", "vcpkg::libnice")
|
||||||
|
elseif is_os("macosx") then
|
||||||
|
add_requires("ffmpeg 5.1.2", {system = false})
|
||||||
|
add_requires("brew::libnice", "brew::glib")
|
||||||
|
end
|
||||||
|
|
||||||
add_packages("spdlog")
|
add_packages("spdlog")
|
||||||
|
|
||||||
includes("thirdparty")
|
includes("thirdparty")
|
||||||
@@ -125,7 +124,7 @@ target("media")
|
|||||||
set_kind("static")
|
set_kind("static")
|
||||||
add_deps("log", "frame")
|
add_deps("log", "frame")
|
||||||
if is_os("windows") then
|
if is_os("windows") then
|
||||||
add_packages("cuda")
|
add_packages("cuda", "vcpkg::ffmpeg")
|
||||||
add_files("src/media/video/encode/*.cpp",
|
add_files("src/media/video/encode/*.cpp",
|
||||||
"src/media/video/decode/*.cpp",
|
"src/media/video/decode/*.cpp",
|
||||||
"src/media/video/encode/nvcodec/*.cpp",
|
"src/media/video/encode/nvcodec/*.cpp",
|
||||||
@@ -143,7 +142,7 @@ target("media")
|
|||||||
add_linkdirs("thirdparty/nvcodec/Lib/x64")
|
add_linkdirs("thirdparty/nvcodec/Lib/x64")
|
||||||
add_links("cuda", "nvencodeapi", "nvcuvid")
|
add_links("cuda", "nvencodeapi", "nvcuvid")
|
||||||
elseif is_os(("linux")) then
|
elseif is_os(("linux")) then
|
||||||
add_packages("cuda")
|
add_packages("cuda", "ffmpeg")
|
||||||
add_files("src/media/video/encode/*.cpp",
|
add_files("src/media/video/encode/*.cpp",
|
||||||
"src/media/video/decode/*.cpp",
|
"src/media/video/decode/*.cpp",
|
||||||
"src/media/video/encode/nvcodec/*.cpp",
|
"src/media/video/encode/nvcodec/*.cpp",
|
||||||
@@ -230,6 +229,6 @@ target("nicetest")
|
|||||||
|
|
||||||
target("linux_capture")
|
target("linux_capture")
|
||||||
set_kind("binary")
|
set_kind("binary")
|
||||||
add_packages("vcpkg::ffmpeg", "sdl2", "asound")
|
add_packages("ffmpeg", "sdl2", "asound")
|
||||||
add_files("tests/peerconnection/linux_capture.cpp")
|
add_files("tests/peerconnection/linux_capture.cpp")
|
||||||
add_ldflags("-lasound", "-lX11", "-lXext", "-lxcb", "-lsndio", "-lpostproc", "-ldl", {force = true})
|
add_ldflags("-lasound", "-lX11", "-lXext", "-lxcb", "-lsndio", "-lpostproc", "-ldl", {force = true})
|
||||||
|
|||||||
Reference in New Issue
Block a user