mirror of
				https://github.com/kunkundi/crossdesk.git
				synced 2025-10-26 20:25:34 +08:00 
			
		
		
		
	Remove files
This commit is contained in:
		| @@ -1,19 +0,0 @@ | |||||||
| // dllmain.cpp : Defines the entry point for the DLL application. |  | ||||||
| #include "pch.h" |  | ||||||
|  |  | ||||||
| BOOL APIENTRY DllMain( HMODULE hModule, |  | ||||||
|                        DWORD  ul_reason_for_call, |  | ||||||
|                        LPVOID lpReserved |  | ||||||
|                      ) |  | ||||||
| { |  | ||||||
|     switch (ul_reason_for_call) |  | ||||||
|     { |  | ||||||
|     case DLL_PROCESS_ATTACH: |  | ||||||
|     case DLL_THREAD_ATTACH: |  | ||||||
|     case DLL_THREAD_DETACH: |  | ||||||
|     case DLL_PROCESS_DETACH: |  | ||||||
|         break; |  | ||||||
|     } |  | ||||||
|     return TRUE; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| #pragma once |  | ||||||
| extern "C" { |  | ||||||
| #include <libavcodec\adts_parser.h> |  | ||||||
| #include <libavcodec\avcodec.h> |  | ||||||
| #include <libavdevice\avdevice.h> |  | ||||||
| #include <libavfilter\avfilter.h> |  | ||||||
| #include <libavfilter\buffersink.h> |  | ||||||
| #include <libavfilter\buffersrc.h> |  | ||||||
| #include <libavformat\avformat.h> |  | ||||||
| #include <libavutil\avassert.h> |  | ||||||
| #include <libavutil\channel_layout.h> |  | ||||||
| #include <libavutil\error.h> |  | ||||||
| #include <libavutil\imgutils.h> |  | ||||||
| #include <libavutil\log.h> |  | ||||||
| #include <libavutil\mathematics.h> |  | ||||||
| #include <libavutil\opt.h> |  | ||||||
| #include <libavutil\samplefmt.h> |  | ||||||
| #include <libavutil\time.h> |  | ||||||
| #include <libavutil\timestamp.h> |  | ||||||
| #include <libswresample\swresample.h> |  | ||||||
| #include <libswscale\swscale.h> |  | ||||||
| } |  | ||||||
| @@ -1,60 +0,0 @@ | |||||||
| #include "log_helper.h" |  | ||||||
|  |  | ||||||
| #include <share.h> |  | ||||||
| #include <stdarg.h> |  | ||||||
| #include <stdio.h> |  | ||||||
|  |  | ||||||
| #include <mutex> |  | ||||||
|  |  | ||||||
| #define AMLOCK(A) std::lock_guard<std::mutex> lock(A) |  | ||||||
|  |  | ||||||
| #define LOG_ROLL_SIZE (1024 * 1024) |  | ||||||
|  |  | ||||||
| AMLog* AMLog::_log = NULL; |  | ||||||
| std::mutex _lock; |  | ||||||
|  |  | ||||||
| AMLog::AMLog(FILE* handle) : _handle(handle) { _log = this; } |  | ||||||
|  |  | ||||||
| AMLog::~AMLog() { |  | ||||||
|   AMLOCK(_lock); |  | ||||||
|   if (_log && _handle) { |  | ||||||
|     fclose(_handle); |  | ||||||
|     _log = NULL; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| AMLog* AMLog::get(const char* path) { |  | ||||||
|   if (_log || !path) { |  | ||||||
|     return _log; |  | ||||||
|   } |  | ||||||
|   // DWORD size = 0; |  | ||||||
|   // HANDLE file = CreateFile(path, GENERIC_READ, 0, NULL, OPEN_EXISTING, |  | ||||||
|   // FILE_ATTRIBUTE_NORMAL, 	NULL); if (file != INVALID_HANDLE_VALUE) { |  | ||||||
|   // size = GetFileSize(file, NULL); 	CloseHandle(file); |  | ||||||
|   // } |  | ||||||
|   // if (size != INVALID_FILE_SIZE && size > LOG_ROLL_SIZE) { |  | ||||||
|   // 	if (DeleteFileA(path) == FALSE) { |  | ||||||
|   // 		TCHAR roll_path[MAX_PATH]; |  | ||||||
|   // 		sprintf_s(roll_path, MAX_PATH, "%s.1", path); |  | ||||||
|   // 		if (!MoveFileEx(path, roll_path, MOVEFILE_REPLACE_EXISTING)) { |  | ||||||
|   // 			return NULL; |  | ||||||
|   // 		} |  | ||||||
|   // 	} |  | ||||||
|   // } |  | ||||||
|   // FILE* handle = _fsopen(path, "a+", _SH_DENYNO); |  | ||||||
|   // if (!handle) { |  | ||||||
|   // 	return NULL; |  | ||||||
|   // } |  | ||||||
|   // _log = new AMLog(handle); |  | ||||||
|   return _log; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void AMLog::printf(const char* format, ...) { |  | ||||||
|   AMLOCK(_lock); |  | ||||||
|   va_list args; |  | ||||||
|  |  | ||||||
|   va_start(args, format); |  | ||||||
|   vfprintf(_handle, format, args); |  | ||||||
|   va_end(args); |  | ||||||
|   fflush(_handle); |  | ||||||
| } |  | ||||||
| @@ -1,63 +0,0 @@ | |||||||
| #ifndef AM_LOG |  | ||||||
| #define AM_LOG |  | ||||||
|  |  | ||||||
| #include <stdio.h> |  | ||||||
| #include <time.h> |  | ||||||
| #include <sys\timeb.h> |  | ||||||
|  |  | ||||||
| #include <windows.h> |  | ||||||
|  |  | ||||||
| class AMLog { |  | ||||||
| public: |  | ||||||
| 	~AMLog(); |  | ||||||
| 	static AMLog* get(const char* path = NULL); |  | ||||||
| 	void printf(const char* format, ...); |  | ||||||
|  |  | ||||||
| private: |  | ||||||
| 	AMLog(FILE* handle); |  | ||||||
|  |  | ||||||
| private: |  | ||||||
| 	static AMLog* _log; |  | ||||||
| 	FILE* _handle; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| enum AM_LOG_TYPE { |  | ||||||
| 	AL_TYPE_DEBUG = 0, |  | ||||||
| 	AL_TYPE_INFO, |  | ||||||
| 	AL_TYPE_WARN, |  | ||||||
| 	AL_TYPE_ERROR, |  | ||||||
| 	AL_TYPE_FATAL, |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| static const char *AM_LOG_STR[] = { "DEBUG", "INFO", "WARN", "ERROR", "FATAL" }; |  | ||||||
|  |  | ||||||
| #define al_printf(type,format,datetime,ms,...)                                 \ |  | ||||||
|          printf("%s-%.3d [%s] [%s(%d)] " format "\n",  datetime,ms,type, __FUNCTION__,__LINE__, ## __VA_ARGS__) |  | ||||||
|  |  | ||||||
| #define PRINT_LINE(type, format, datetime, ms, ...)                     \ |  | ||||||
|     printf("%s-%.3d [%s] [%s(%d)] " format "\n",  datetime,ms,type, __FUNCTION__,__LINE__, ## __VA_ARGS__) |  | ||||||
|  |  | ||||||
| #define al_log(type,format,...) do{                                            \ |  | ||||||
| 	struct _timeb now;                                                           \ |  | ||||||
| 	struct tm today;                                                             \ |  | ||||||
| 	char datetime_str[20];                                                       \ |  | ||||||
| 	_ftime_s(&now);                                                              \ |  | ||||||
| 	localtime_s(&today, &now.time);                                              \ |  | ||||||
| 	strftime(datetime_str, 20, "%Y-%m-%d %H:%M:%S", &today);                     \ |  | ||||||
| 	AMLog *am_log = AMLog::get();                                                \ |  | ||||||
| 	if(am_log){                                                                     \ |  | ||||||
| 		am_log->PRINT_LINE(AM_LOG_STR[type], format, datetime_str, now.millitm, ## __VA_ARGS__);  \ |  | ||||||
| 	} else {                                                                      \ |  | ||||||
| 		al_printf(AM_LOG_STR[type], format, datetime_str, now.millitm, ## __VA_ARGS__);  \ |  | ||||||
| 	}                                                                             \ |  | ||||||
| }while (0)    |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #define al_debug(format, ...) al_log(AL_TYPE_DEBUG, format, ## __VA_ARGS__) |  | ||||||
| #define al_info(format, ...) al_log(AL_TYPE_INFO, format, ## __VA_ARGS__) |  | ||||||
| #define al_warn(format, ...) al_log(AL_TYPE_WARN, format, ## __VA_ARGS__) |  | ||||||
| #define al_error(format, ...) al_log(AL_TYPE_ERROR, format, ## __VA_ARGS__) |  | ||||||
| #define al_fatal(format, ...) al_log(AL_TYPE_FATAL, format, ## __VA_ARGS__) |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
| @@ -15,11 +15,11 @@ int main() { | |||||||
|  |  | ||||||
|   static am::record_desktop *recorder = new am::record_desktop_wgc(); |   static am::record_desktop *recorder = new am::record_desktop_wgc(); | ||||||
|  |  | ||||||
| 	RECORD_DESKTOP_RECT rect; |   RECORD_DESKTOP_RECT rect; | ||||||
| 	rect.left = 0; |   rect.left = 0; | ||||||
| 	rect.top = 0; |   rect.top = 0; | ||||||
| 	rect.right = GetSystemMetrics(SM_CXSCREEN); |   rect.right = GetSystemMetrics(SM_CXSCREEN); | ||||||
| 	rect.bottom = GetSystemMetrics(SM_CYSCREEN); |   rect.bottom = GetSystemMetrics(SM_CYSCREEN); | ||||||
|  |  | ||||||
|   recorder->init(rect, 10); |   recorder->init(rect, 10); | ||||||
|  |  | ||||||
| @@ -28,7 +28,8 @@ int main() { | |||||||
|   // int resume() override; |   // int resume() override; | ||||||
|   // int stop() override; |   // int stop() override; | ||||||
|  |  | ||||||
|   while(1){} |   while (1) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
| @@ -1,80 +1,124 @@ | |||||||
| #ifndef RECORD_DESKTOP | #ifndef RECORD_DESKTOP | ||||||
| #define RECORD_DESKTOP | #define RECORD_DESKTOP | ||||||
|  |  | ||||||
| #include "record_desktop_define.h" | extern "C" { | ||||||
|  | #include <libavcodec\adts_parser.h> | ||||||
| #include "headers_ffmpeg.h" | #include <libavcodec\avcodec.h> | ||||||
|  | #include <libavdevice\avdevice.h> | ||||||
| #include <atomic> | #include <libavfilter\avfilter.h> | ||||||
| #include <thread> | #include <libavfilter\buffersink.h> | ||||||
| #include <functional> | #include <libavfilter\buffersrc.h> | ||||||
| #include <string> | #include <libavformat\avformat.h> | ||||||
|  | #include <libavutil\avassert.h> | ||||||
| namespace am { | #include <libavutil\channel_layout.h> | ||||||
| 	typedef std::function<void(AVFrame *frame)> cb_desktop_data; | #include <libavutil\error.h> | ||||||
| 	typedef std::function<void(int)> cb_desktop_error; | #include <libavutil\imgutils.h> | ||||||
|  | #include <libavutil\log.h> | ||||||
| 	class record_desktop | #include <libavutil\mathematics.h> | ||||||
| 	{ | #include <libavutil\opt.h> | ||||||
| 	public: | #include <libavutil\samplefmt.h> | ||||||
| 		record_desktop(); | #include <libavutil\time.h> | ||||||
| 		virtual ~record_desktop(); | #include <libavutil\timestamp.h> | ||||||
|  | #include <libswresample\swresample.h> | ||||||
| 		virtual int init( | #include <libswscale\swscale.h> | ||||||
| 			const RECORD_DESKTOP_RECT &rect, |  | ||||||
| 			const int fps |  | ||||||
| 		) = 0; |  | ||||||
|  |  | ||||||
| 		virtual int start() = 0; |  | ||||||
| 		virtual int pause() = 0; |  | ||||||
| 		virtual int resume() = 0; |  | ||||||
| 		virtual int stop() = 0; |  | ||||||
|  |  | ||||||
| 		inline const AVRational & get_time_base() { return _time_base; } |  | ||||||
|  |  | ||||||
| 		inline int64_t get_start_time() { return _start_time; } |  | ||||||
|  |  | ||||||
| 		inline AVPixelFormat get_pixel_fmt() { return _pixel_fmt; } |  | ||||||
|  |  | ||||||
| 	public: |  | ||||||
| 		inline bool is_recording() { return _running; } |  | ||||||
| 		inline const std::string & get_device_name() { return _device_name; } |  | ||||||
| 		inline const RECORD_DESKTOP_DATA_TYPES get_data_type() { return _data_type; } |  | ||||||
| 		inline void registe_cb( |  | ||||||
| 			cb_desktop_data on_data, |  | ||||||
| 			cb_desktop_error on_error) { |  | ||||||
| 			_on_data = on_data; |  | ||||||
| 			_on_error = on_error; |  | ||||||
| 		} |  | ||||||
| 		inline const RECORD_DESKTOP_RECT & get_rect() { return _rect; } |  | ||||||
|  |  | ||||||
| 		inline const int get_frame_rate() { return _fps; } |  | ||||||
|  |  | ||||||
| 	protected: |  | ||||||
| 		virtual void clean_up() = 0; |  | ||||||
|  |  | ||||||
| 	protected: |  | ||||||
| 		std::atomic_bool _running; |  | ||||||
| 		std::atomic_bool _paused; |  | ||||||
| 		std::atomic_bool _inited; |  | ||||||
|  |  | ||||||
| 		std::thread _thread; |  | ||||||
|  |  | ||||||
| 		std::string _device_name; |  | ||||||
|  |  | ||||||
| 		RECORD_DESKTOP_RECT _rect; |  | ||||||
| 		RECORD_DESKTOP_DATA_TYPES _data_type; |  | ||||||
|  |  | ||||||
| 		int _fps; |  | ||||||
|  |  | ||||||
| 		cb_desktop_data _on_data; |  | ||||||
| 		cb_desktop_error _on_error; |  | ||||||
|  |  | ||||||
| 		AVRational _time_base; |  | ||||||
| 		int64_t _start_time; |  | ||||||
| 		AVPixelFormat _pixel_fmt; |  | ||||||
| 	}; |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #include <atomic> | ||||||
|  | #include <functional> | ||||||
|  | #include <string> | ||||||
|  | #include <thread> | ||||||
|  |  | ||||||
|  | typedef enum { | ||||||
|  |   DT_DESKTOP_NO = 0, | ||||||
|  |   DT_DESKTOP_FFMPEG_GDI, | ||||||
|  |   DT_DESKTOP_FFMPEG_DSHOW, | ||||||
|  |   DT_DESKTOP_WIN_GDI, | ||||||
|  |   DT_DESKTOP_WIN_DUPLICATION, | ||||||
|  |   DT_DESKTOP_WIN_WGC, | ||||||
|  |   DT_DESKTOP_WIN_MAG | ||||||
|  | } RECORD_DESKTOP_TYPES; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Record desktop data type | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | typedef enum { | ||||||
|  |   AT_DESKTOP_NO = 0, | ||||||
|  |   AT_DESKTOP_RGBA, | ||||||
|  |   AT_DESKTOP_BGRA | ||||||
|  | } RECORD_DESKTOP_DATA_TYPES; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Record desktop rect | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | typedef struct { | ||||||
|  |   int left; | ||||||
|  |   int top; | ||||||
|  |   int right; | ||||||
|  |   int bottom; | ||||||
|  | } RECORD_DESKTOP_RECT; | ||||||
|  |  | ||||||
|  | namespace am { | ||||||
|  | typedef std::function<void(AVFrame *frame)> cb_desktop_data; | ||||||
|  | typedef std::function<void(int)> cb_desktop_error; | ||||||
|  |  | ||||||
|  | class record_desktop { | ||||||
|  |  public: | ||||||
|  |   record_desktop(); | ||||||
|  |   virtual ~record_desktop(); | ||||||
|  |  | ||||||
|  |   virtual int init(const RECORD_DESKTOP_RECT &rect, const int fps) = 0; | ||||||
|  |  | ||||||
|  |   virtual int start() = 0; | ||||||
|  |   virtual int pause() = 0; | ||||||
|  |   virtual int resume() = 0; | ||||||
|  |   virtual int stop() = 0; | ||||||
|  |  | ||||||
|  |   inline const AVRational &get_time_base() { return _time_base; } | ||||||
|  |  | ||||||
|  |   inline int64_t get_start_time() { return _start_time; } | ||||||
|  |  | ||||||
|  |   inline AVPixelFormat get_pixel_fmt() { return _pixel_fmt; } | ||||||
|  |  | ||||||
|  |  public: | ||||||
|  |   inline bool is_recording() { return _running; } | ||||||
|  |   inline const std::string &get_device_name() { return _device_name; } | ||||||
|  |   inline const RECORD_DESKTOP_DATA_TYPES get_data_type() { return _data_type; } | ||||||
|  |   inline void registe_cb(cb_desktop_data on_data, cb_desktop_error on_error) { | ||||||
|  |     _on_data = on_data; | ||||||
|  |     _on_error = on_error; | ||||||
|  |   } | ||||||
|  |   inline const RECORD_DESKTOP_RECT &get_rect() { return _rect; } | ||||||
|  |  | ||||||
|  |   inline const int get_frame_rate() { return _fps; } | ||||||
|  |  | ||||||
|  |  protected: | ||||||
|  |   virtual void clean_up() = 0; | ||||||
|  |  | ||||||
|  |  protected: | ||||||
|  |   std::atomic_bool _running; | ||||||
|  |   std::atomic_bool _paused; | ||||||
|  |   std::atomic_bool _inited; | ||||||
|  |  | ||||||
|  |   std::thread _thread; | ||||||
|  |  | ||||||
|  |   std::string _device_name; | ||||||
|  |  | ||||||
|  |   RECORD_DESKTOP_RECT _rect; | ||||||
|  |   RECORD_DESKTOP_DATA_TYPES _data_type; | ||||||
|  |  | ||||||
|  |   int _fps; | ||||||
|  |  | ||||||
|  |   cb_desktop_data _on_data; | ||||||
|  |   cb_desktop_error _on_error; | ||||||
|  |  | ||||||
|  |   AVRational _time_base; | ||||||
|  |   int64_t _start_time; | ||||||
|  |   AVPixelFormat _pixel_fmt; | ||||||
|  | }; | ||||||
|  | }  // namespace am | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
| @@ -1,45 +0,0 @@ | |||||||
| #ifndef RECORD_DESKTOP_DEFINE |  | ||||||
| #define RECORD_DESKTOP_DEFINE |  | ||||||
|  |  | ||||||
| /* |  | ||||||
| * Record typee |  | ||||||
| * |  | ||||||
| */ |  | ||||||
| typedef enum { |  | ||||||
| 	DT_DESKTOP_NO = 0, |  | ||||||
| 	DT_DESKTOP_FFMPEG_GDI, |  | ||||||
| 	DT_DESKTOP_FFMPEG_DSHOW, |  | ||||||
| 	DT_DESKTOP_WIN_GDI, |  | ||||||
| 	DT_DESKTOP_WIN_DUPLICATION, |  | ||||||
|   DT_DESKTOP_WIN_WGC, |  | ||||||
| 	DT_DESKTOP_WIN_MAG |  | ||||||
| }RECORD_DESKTOP_TYPES; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
| * Record desktop data type |  | ||||||
| * |  | ||||||
| */ |  | ||||||
|  |  | ||||||
| typedef enum { |  | ||||||
| 	AT_DESKTOP_NO = 0, |  | ||||||
| 	AT_DESKTOP_RGBA, |  | ||||||
| 	AT_DESKTOP_BGRA |  | ||||||
| }RECORD_DESKTOP_DATA_TYPES; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
| * Record desktop rect |  | ||||||
| * |  | ||||||
| */ |  | ||||||
|  |  | ||||||
| typedef struct { |  | ||||||
| 	int left; |  | ||||||
| 	int top; |  | ||||||
| 	int right; |  | ||||||
| 	int bottom; |  | ||||||
| }RECORD_DESKTOP_RECT; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
| @@ -1,21 +1,15 @@ | |||||||
| #include "record_desktop_wgc.h" | #include "record_desktop_wgc.h" | ||||||
|  |  | ||||||
| #include "utils_string.h" |  | ||||||
|  |  | ||||||
| #include "system_error.h" |  | ||||||
| #include "error_define.h" | #include "error_define.h" | ||||||
| #include "log_helper.h" |  | ||||||
|  |  | ||||||
| BOOL WINAPI EnumMonitorProc(HMONITOR hmonitor, HDC hdc, LPRECT lprc, | BOOL WINAPI EnumMonitorProc(HMONITOR hmonitor, HDC hdc, LPRECT lprc, | ||||||
|                             LPARAM data) { |                             LPARAM data) { | ||||||
|  |  | ||||||
|   MONITORINFOEX info_ex; |   MONITORINFOEX info_ex; | ||||||
|   info_ex.cbSize = sizeof(MONITORINFOEX); |   info_ex.cbSize = sizeof(MONITORINFOEX); | ||||||
|  |  | ||||||
|   GetMonitorInfo(hmonitor, &info_ex); |   GetMonitorInfo(hmonitor, &info_ex); | ||||||
|  |  | ||||||
|   if (info_ex.dwFlags == DISPLAY_DEVICE_MIRRORING_DRIVER) |   if (info_ex.dwFlags == DISPLAY_DEVICE_MIRRORING_DRIVER) return true; | ||||||
|     return true; |  | ||||||
|  |  | ||||||
|   if (info_ex.dwFlags & MONITORINFOF_PRIMARY) { |   if (info_ex.dwFlags & MONITORINFOF_PRIMARY) { | ||||||
|     *(HMONITOR *)data = hmonitor; |     *(HMONITOR *)data = hmonitor; | ||||||
| @@ -34,7 +28,6 @@ HMONITOR GetPrimaryMonitor() { | |||||||
|  |  | ||||||
| namespace am { | namespace am { | ||||||
|  |  | ||||||
|  |  | ||||||
| record_desktop_wgc::record_desktop_wgc() {} | record_desktop_wgc::record_desktop_wgc() {} | ||||||
|  |  | ||||||
| record_desktop_wgc::~record_desktop_wgc() { | record_desktop_wgc::~record_desktop_wgc() { | ||||||
| @@ -44,8 +37,7 @@ record_desktop_wgc::~record_desktop_wgc() { | |||||||
|  |  | ||||||
| int record_desktop_wgc::init(const RECORD_DESKTOP_RECT &rect, const int fps) { | int record_desktop_wgc::init(const RECORD_DESKTOP_RECT &rect, const int fps) { | ||||||
|   int error = AE_NO; |   int error = AE_NO; | ||||||
|   if (_inited == true) |   if (_inited == true) return error; | ||||||
|     return error; |  | ||||||
|  |  | ||||||
|   _fps = fps; |   _fps = fps; | ||||||
|   _rect = rect; |   _rect = rect; | ||||||
| @@ -73,8 +65,6 @@ int record_desktop_wgc::init(const RECORD_DESKTOP_RECT &rect, const int fps) { | |||||||
|   } while (0); |   } while (0); | ||||||
|  |  | ||||||
|   if (error != AE_NO) { |   if (error != AE_NO) { | ||||||
|     al_debug("%s,last error:%s", err2str(error), |  | ||||||
|              system_error::error2str(GetLastError()).c_str()); |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   return error; |   return error; | ||||||
| @@ -82,7 +72,7 @@ int record_desktop_wgc::init(const RECORD_DESKTOP_RECT &rect, const int fps) { | |||||||
|  |  | ||||||
| int record_desktop_wgc::start() { | int record_desktop_wgc::start() { | ||||||
|   if (_running == true) { |   if (_running == true) { | ||||||
|     al_warn("record desktop duplication is already running"); |     // al_warn("record desktop duplication is already running"); | ||||||
|     return AE_NO; |     return AE_NO; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -98,29 +88,26 @@ int record_desktop_wgc::start() { | |||||||
|  |  | ||||||
| int record_desktop_wgc::pause() { | int record_desktop_wgc::pause() { | ||||||
|   _paused = true; |   _paused = true; | ||||||
|   if (session_) |   if (session_) session_->pause(); | ||||||
|     session_->pause(); |  | ||||||
|   return AE_NO; |   return AE_NO; | ||||||
| } | } | ||||||
|  |  | ||||||
| int record_desktop_wgc::resume() { | int record_desktop_wgc::resume() { | ||||||
|   _paused = false; |   _paused = false; | ||||||
|   if (session_) |   if (session_) session_->resume(); | ||||||
|     session_->resume(); |  | ||||||
|   return AE_NO; |   return AE_NO; | ||||||
| } | } | ||||||
|  |  | ||||||
| int record_desktop_wgc::stop() { | int record_desktop_wgc::stop() { | ||||||
|   _running = false; |   _running = false; | ||||||
|  |  | ||||||
|   if (session_) |   if (session_) session_->stop(); | ||||||
|     session_->stop(); |  | ||||||
|  |  | ||||||
|   return AE_NO; |   return AE_NO; | ||||||
| } | } | ||||||
|  |  | ||||||
| void record_desktop_wgc::on_frame(const wgc_session::wgc_session_frame &frame) { | void record_desktop_wgc::on_frame(const wgc_session::wgc_session_frame &frame) { | ||||||
|   al_debug("wgc on frame"); |   // al_debug("wgc on frame"); | ||||||
|   AVFrame *av_frame = av_frame_alloc(); |   AVFrame *av_frame = av_frame_alloc(); | ||||||
|  |  | ||||||
|   av_frame->pts = av_gettime_relative(); |   av_frame->pts = av_gettime_relative(); | ||||||
| @@ -136,8 +123,7 @@ void record_desktop_wgc::on_frame(const wgc_session::wgc_session_frame &frame) { | |||||||
|   av_image_fill_arrays(av_frame->data, av_frame->linesize, frame.data, |   av_image_fill_arrays(av_frame->data, av_frame->linesize, frame.data, | ||||||
|                        AV_PIX_FMT_BGRA, frame.width, frame.height, 1); |                        AV_PIX_FMT_BGRA, frame.width, frame.height, 1); | ||||||
|  |  | ||||||
|   if (_on_data) |   if (_on_data) _on_data(av_frame); | ||||||
|     _on_data(av_frame); |  | ||||||
|  |  | ||||||
|   av_frame_free(&av_frame); |   av_frame_free(&av_frame); | ||||||
| } | } | ||||||
| @@ -145,10 +131,9 @@ void record_desktop_wgc::on_frame(const wgc_session::wgc_session_frame &frame) { | |||||||
| void record_desktop_wgc::clean_up() { | void record_desktop_wgc::clean_up() { | ||||||
|   _inited = false; |   _inited = false; | ||||||
|  |  | ||||||
|   if (session_) |   if (session_) session_->release(); | ||||||
|     session_->release(); |  | ||||||
|  |  | ||||||
|   session_ = nullptr; |   session_ = nullptr; | ||||||
| } | } | ||||||
|  |  | ||||||
| } // namespace am | }  // namespace am | ||||||
| @@ -1,39 +0,0 @@ | |||||||
| #include "system_error.h" |  | ||||||
|  |  | ||||||
| #include <Windows.h> |  | ||||||
|  |  | ||||||
| namespace am { |  | ||||||
|  |  | ||||||
| const std::string& system_error::error2str(unsigned long error) { |  | ||||||
|   // DWORD system_locale = MAKELANGID(LANG_NEUTRAL, SUBLANG_NEUTRAL); |  | ||||||
|  |  | ||||||
|   // HLOCAL local_buf = nullptr; |  | ||||||
|  |  | ||||||
|   // BOOL ret = FormatMessage( |  | ||||||
|   // 	FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS | |  | ||||||
|   // FORMAT_MESSAGE_ALLOCATE_BUFFER, 	NULL, error, system_locale,(PSTR) |  | ||||||
|   // &local_buf, 0, NULL); |  | ||||||
|  |  | ||||||
|   // if (!ret) { |  | ||||||
|   // 	HMODULE hnetmsg = LoadLibraryEx("netmsg.dll", NULL, |  | ||||||
|   // DONT_RESOLVE_DLL_REFERENCES); 	if (hnetmsg != nullptr) { |  | ||||||
|   // ret = FormatMessage( 			FORMAT_MESSAGE_FROM_HMODULE | |  | ||||||
|   // FORMAT_MESSAGE_IGNORE_INSERTS | FORMAT_MESSAGE_ALLOCATE_BUFFER, |  | ||||||
|   // hnetmsg, error, system_locale, (PSTR)&local_buf, 0, NULL); |  | ||||||
|  |  | ||||||
|   // 		FreeLibrary(hnetmsg); |  | ||||||
|   // 	} |  | ||||||
|   // } |  | ||||||
|  |  | ||||||
|   // std::string error_str; |  | ||||||
|  |  | ||||||
|   // if (ret) { |  | ||||||
|   // 	error_str = (LPCTSTR)LocalLock(local_buf); |  | ||||||
|   // 	LocalFree(local_buf); |  | ||||||
|   // } |  | ||||||
|  |  | ||||||
|   // return error_str; |  | ||||||
|   return ""; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| }  // namespace am |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include <string> |  | ||||||
|  |  | ||||||
| namespace am { |  | ||||||
|  |  | ||||||
| class system_error { |  | ||||||
| public: |  | ||||||
| 	static const std::string& error2str(unsigned long error); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -1,66 +0,0 @@ | |||||||
| #include "utils_string.h" |  | ||||||
|  |  | ||||||
| #include <Windows.h> |  | ||||||
| #ifdef WIN32 |  | ||||||
|  |  | ||||||
| #include <Windows.h> |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| namespace am { |  | ||||||
|  |  | ||||||
| std::wstring utils_string::ascii_unicode(const std::string &str) { |  | ||||||
|   int unicodeLen = MultiByteToWideChar(CP_ACP, 0, str.c_str(), -1, nullptr, 0); |  | ||||||
|  |  | ||||||
|   wchar_t *pUnicode = (wchar_t *)malloc(sizeof(wchar_t) * unicodeLen); |  | ||||||
|  |  | ||||||
|   MultiByteToWideChar(CP_ACP, 0, str.c_str(), -1, pUnicode, unicodeLen); |  | ||||||
|  |  | ||||||
|   std::wstring ret_str = pUnicode; |  | ||||||
|  |  | ||||||
|   free(pUnicode); |  | ||||||
|  |  | ||||||
|   return ret_str; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| std::string utils_string::unicode_ascii(const std::wstring &wstr) { |  | ||||||
|   int ansiiLen = WideCharToMultiByte(CP_ACP, 0, wstr.c_str(), -1, nullptr, 0, |  | ||||||
|                                      nullptr, nullptr); |  | ||||||
|   char *pAssii = (char *)malloc(sizeof(char) * ansiiLen); |  | ||||||
|   WideCharToMultiByte(CP_ACP, 0, wstr.c_str(), -1, pAssii, ansiiLen, nullptr, |  | ||||||
|                       nullptr); |  | ||||||
|   std::string ret_str = pAssii; |  | ||||||
|   free(pAssii); |  | ||||||
|   return ret_str; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| std::string utils_string::ascii_utf8(const std::string &str) { |  | ||||||
|   return unicode_utf8(ascii_unicode(str)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| std::string utils_string::utf8_ascii(const std::string &utf8) { |  | ||||||
|   return unicode_ascii(utf8_unicode(utf8)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| std::string utils_string::unicode_utf8(const std::wstring &wstr) { |  | ||||||
|   int ansiiLen = WideCharToMultiByte(CP_UTF8, 0, wstr.c_str(), -1, nullptr, 0, |  | ||||||
|                                      nullptr, nullptr); |  | ||||||
|   char *pAssii = (char *)malloc(sizeof(char) * ansiiLen); |  | ||||||
|   WideCharToMultiByte(CP_UTF8, 0, wstr.c_str(), -1, pAssii, ansiiLen, nullptr, |  | ||||||
|                       nullptr); |  | ||||||
|   std::string ret_str = pAssii; |  | ||||||
|   free(pAssii); |  | ||||||
|   return ret_str; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| std::wstring utils_string::utf8_unicode(const std::string &utf8) { |  | ||||||
|   int unicodeLen = |  | ||||||
|       MultiByteToWideChar(CP_UTF8, 0, utf8.c_str(), -1, nullptr, 0); |  | ||||||
|   wchar_t *pUnicode = (wchar_t *)malloc(sizeof(wchar_t) * unicodeLen); |  | ||||||
|   MultiByteToWideChar(CP_UTF8, 0, utf8.c_str(), -1, pUnicode, unicodeLen); |  | ||||||
|   std::wstring ret_str = pUnicode; |  | ||||||
|   free(pUnicode); |  | ||||||
|   return ret_str; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| }  // namespace am |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include <string> |  | ||||||
|  |  | ||||||
| namespace am { |  | ||||||
|  |  | ||||||
| 	class utils_string |  | ||||||
| 	{ |  | ||||||
| 	public: |  | ||||||
| 		static std::wstring ascii_unicode(const std::string & str); |  | ||||||
|  |  | ||||||
| 		static std::string unicode_ascii(const std::wstring &wstr); |  | ||||||
|  |  | ||||||
| 		static std::string ascii_utf8(const std::string & str); |  | ||||||
|  |  | ||||||
| 		static std::string utf8_ascii(const std::string &utf8); |  | ||||||
|  |  | ||||||
| 		static std::string  unicode_utf8(const std::wstring& wstr); |  | ||||||
|  |  | ||||||
| 		static std::wstring utf8_unicode(const std::string &utf8); |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| } |  | ||||||
		Reference in New Issue
	
	Block a user