mirror of
https://github.com/tuxbox-neutrino/neutrino.git
synced 2025-09-01 09:51:22 +02:00
Merge branch 'master' into pu/mp
Conflicts: src/driver/screenshot.cpp src/Makefile.am
This commit is contained in:
@@ -21,11 +21,6 @@ if test "$DEBUG" = "yes"; then
|
|||||||
AC_DEFINE(DEBUG,1,[Enable debug messages])
|
AC_DEFINE(DEBUG,1,[Enable debug messages])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
AC_ARG_ENABLE(tmsdk,
|
|
||||||
AS_HELP_STRING(--enable-tmsdk, compile inside sdk),
|
|
||||||
,[enable_tmsdk=no])
|
|
||||||
AM_CONDITIONAL(ENABLE_TMSDK,test "$enable_tmsdk" = "yes")
|
|
||||||
|
|
||||||
AC_MSG_CHECKING(target)
|
AC_MSG_CHECKING(target)
|
||||||
|
|
||||||
if test "$TARGET" = "native"; then
|
if test "$TARGET" = "native"; then
|
||||||
|
@@ -145,14 +145,12 @@ if BOXTYPE_COOL
|
|||||||
neutrino_LDADD += \
|
neutrino_LDADD += \
|
||||||
$(top_builddir)/lib/hardware/coolstream/libhwcaps.a
|
$(top_builddir)/lib/hardware/coolstream/libhwcaps.a
|
||||||
neutrino_LDADD += -lcoolstream-mt -lca-sc
|
neutrino_LDADD += -lcoolstream-mt -lca-sc
|
||||||
if ENABLE_TMSDK
|
|
||||||
else
|
|
||||||
if BOXMODEL_CS_HD2
|
if BOXMODEL_CS_HD2
|
||||||
neutrino_LDADD += -lca-ci -llnxtmvssUsr -llnxUKAL -llnxplatUsr -llnxtmasUsr -llnxdvbciUsr -llnxpvrUsr -llnxcssUsr -llnxnotifyqUsr -ltmpvrDataManager-cst -ltmpvrIndexStorage -llnxscsUsr
|
neutrino_LDADD += -lca-ci -llnxtmvssUsr -llnxUKAL -llnxplatUsr -llnxtmasUsr -llnxdvbciUsr -llnxpvrUsr -llnxcssUsr -llnxnotifyqUsr -ltmpvrDataManager-cst -ltmpvrIndexStorage -llnxscsUsr
|
||||||
else
|
else
|
||||||
neutrino_LDADD += -lnxp
|
neutrino_LDADD += -lnxp
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
|
|
||||||
if BOXMODEL_CS_HD2
|
if BOXMODEL_CS_HD2
|
||||||
neutrino_LDADD += -liconv
|
neutrino_LDADD += -liconv
|
||||||
|
@@ -2,6 +2,7 @@
|
|||||||
Neutrino-GUI - DBoxII-Project
|
Neutrino-GUI - DBoxII-Project
|
||||||
|
|
||||||
Copyright (C) 2011 CoolStream International Ltd
|
Copyright (C) 2011 CoolStream International Ltd
|
||||||
|
Copyright (C) 2017 M. Liebmann (micha-bbg)
|
||||||
|
|
||||||
parts based on AiO Screengrabber (C) Seddi seddi@ihad.tv
|
parts based on AiO Screengrabber (C) Seddi seddi@ihad.tv
|
||||||
|
|
||||||
@@ -62,6 +63,9 @@ CScreenShot::CScreenShot(const std::string fname, screenshot_format_t fmt)
|
|||||||
fd = NULL;
|
fd = NULL;
|
||||||
xres = 0;
|
xres = 0;
|
||||||
yres = 0;
|
yres = 0;
|
||||||
|
scs_thread = 0;
|
||||||
|
pthread_mutex_init(&thread_mutex, NULL);
|
||||||
|
pthread_mutex_init(&getData_mutex, NULL);
|
||||||
get_video = g_settings.screenshot_video;
|
get_video = g_settings.screenshot_video;
|
||||||
get_osd = g_settings.screenshot_mode;
|
get_osd = g_settings.screenshot_mode;
|
||||||
scale_to_video = g_settings.screenshot_scale;
|
scale_to_video = g_settings.screenshot_scale;
|
||||||
@@ -69,15 +73,17 @@ CScreenShot::CScreenShot(const std::string fname, screenshot_format_t fmt)
|
|||||||
|
|
||||||
CScreenShot::~CScreenShot()
|
CScreenShot::~CScreenShot()
|
||||||
{
|
{
|
||||||
|
pthread_mutex_destroy(&thread_mutex);
|
||||||
|
pthread_mutex_destroy(&getData_mutex);
|
||||||
|
// printf("[CScreenShot::%s:%d] thread: %p\n", __func__, __LINE__, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* try to get video frame data in ARGB format, restore GXA state */
|
/* try to get video frame data in ARGB format, restore GXA state */
|
||||||
bool CScreenShot::GetData()
|
bool CScreenShot::GetData()
|
||||||
{
|
{
|
||||||
static OpenThreads::Mutex mutex;
|
|
||||||
bool res = false;
|
bool res = false;
|
||||||
|
pthread_mutex_lock(&getData_mutex);
|
||||||
|
|
||||||
mutex.lock();
|
|
||||||
#ifdef BOXMODEL_CS_HD1
|
#ifdef BOXMODEL_CS_HD1
|
||||||
CFrameBuffer::getInstance()->setActive(false);
|
CFrameBuffer::getInstance()->setActive(false);
|
||||||
#endif
|
#endif
|
||||||
@@ -91,52 +97,88 @@ bool CScreenShot::GetData()
|
|||||||
/* sort of hack. GXA used to transfer/convert live image to RGB,
|
/* sort of hack. GXA used to transfer/convert live image to RGB,
|
||||||
* so setup GXA back */
|
* so setup GXA back */
|
||||||
CFrameBuffer::getInstance()->setupGXA();
|
CFrameBuffer::getInstance()->setupGXA();
|
||||||
//CFrameBuffer::getInstance()->add_gxa_sync_marker();
|
CFrameBuffer::getInstance()->add_gxa_sync_marker();
|
||||||
CFrameBuffer::getInstance()->setActive(true);
|
CFrameBuffer::getInstance()->setActive(true);
|
||||||
#endif
|
#endif
|
||||||
mutex.unlock();
|
pthread_mutex_unlock(&getData_mutex);
|
||||||
if (!res) {
|
if (!res) {
|
||||||
printf("CScreenShot::Start: GetScreenImage failed\n");
|
printf("[CScreenShot::%s:%d] GetScreenImage failed\n", __func__, __LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("CScreenShot::GetData: data: %p %d x %d\n", pixel_data, xres, yres);
|
printf("[CScreenShot::%s:%d] data: %p %d x %d\n", __func__, __LINE__, pixel_data, xres, yres);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool CScreenShot::startThread()
|
||||||
|
{
|
||||||
|
if (!scs_thread) {
|
||||||
|
void *ptr = static_cast<void*>(this);
|
||||||
|
int res = pthread_create(&scs_thread, NULL, initThread, ptr);
|
||||||
|
if (res != 0) {
|
||||||
|
printf("[CScreenShot::%s:%d] ERROR! pthread_create\n", __func__, __LINE__);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
pthread_detach(scs_thread);
|
||||||
|
pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, 0);
|
||||||
|
pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, 0);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* CScreenShot::initThread(void *arg)
|
||||||
|
{
|
||||||
|
CScreenShot *scs = static_cast<CScreenShot*>(arg);
|
||||||
|
pthread_cleanup_push(cleanupThread, scs);
|
||||||
|
// printf("[CScreenShot::%s:%d] thread: %p\n", __func__, __LINE__, scs);
|
||||||
|
|
||||||
|
scs->runThread();
|
||||||
|
pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, 0);
|
||||||
|
pthread_exit(0);
|
||||||
|
|
||||||
|
pthread_cleanup_pop(0);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* thread function to save data asynchroniosly. delete itself after saving */
|
||||||
|
void CScreenShot::runThread()
|
||||||
|
{
|
||||||
|
pthread_mutex_lock(&thread_mutex);
|
||||||
|
printf("[CScreenShot::%s:%d] save to %s format %d\n", __func__, __LINE__, filename.c_str(), format);
|
||||||
|
|
||||||
|
bool ret = SaveFile();
|
||||||
|
|
||||||
|
printf("[CScreenShot::%s:%d] %s finished: %d\n", __func__, __LINE__, filename.c_str(), ret);
|
||||||
|
pthread_mutex_unlock(&thread_mutex);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CScreenShot::cleanupThread(void *arg)
|
||||||
|
{
|
||||||
|
CScreenShot *scs = static_cast<CScreenShot*>(arg);
|
||||||
|
// printf("[CScreenShot::%s:%d] thread: %p\n", __func__, __LINE__, scs);
|
||||||
|
delete scs;
|
||||||
|
}
|
||||||
|
|
||||||
/* start ::run in new thread to save file in selected format */
|
/* start ::run in new thread to save file in selected format */
|
||||||
bool CScreenShot::Start()
|
bool CScreenShot::Start()
|
||||||
{
|
{
|
||||||
set_threadname("n:screenshot");
|
set_threadname("n:screenshot");
|
||||||
bool ret = false;
|
bool ret = false;
|
||||||
if(GetData())
|
if (GetData())
|
||||||
ret = (start() == 0);
|
ret = startThread();
|
||||||
else
|
else
|
||||||
delete this;
|
delete this;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* thread function to save data asynchroniosly. delete itself after saving */
|
|
||||||
void CScreenShot::run()
|
|
||||||
{
|
|
||||||
printf("CScreenShot::run save to %s format %d\n", filename.c_str(), format);
|
|
||||||
detach();
|
|
||||||
setCancelModeDisable();
|
|
||||||
setSchedulePriority(THREAD_PRIORITY_MIN);
|
|
||||||
bool ret = SaveFile();
|
|
||||||
printf("CScreenShot::run: %s finished: %d\n", filename.c_str(), ret);
|
|
||||||
delete this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* save file in sync mode, return true if save ok, or false */
|
/* save file in sync mode, return true if save ok, or false */
|
||||||
bool CScreenShot::StartSync()
|
bool CScreenShot::StartSync()
|
||||||
{
|
{
|
||||||
bool ret = false;
|
bool ret = false;
|
||||||
printf("CScreenShot::StartSync save to %s format %d\n", filename.c_str(), format);
|
printf("[CScreenShot::%s:%d] save to %s format %d\n", __func__, __LINE__, filename.c_str(), format);
|
||||||
if(GetData())
|
if (GetData())
|
||||||
ret = SaveFile();
|
ret = SaveFile();
|
||||||
|
printf("[CScreenShot::%s:%d] %s finished: %d\n", __func__, __LINE__, filename.c_str(), ret);
|
||||||
printf("CScreenShot::StartSync: %s finished: %d\n", filename.c_str(), ret);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -226,7 +268,7 @@ bool CScreenShot::SavePng()
|
|||||||
|
|
||||||
free(row_pointers);
|
free(row_pointers);
|
||||||
fclose(fd);
|
fclose(fd);
|
||||||
TIMER_STOP(filename.c_str());
|
TIMER_STOP(("[CScreenShot::SavePng] " + filename).c_str());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -307,7 +349,7 @@ bool CScreenShot::SaveJpg()
|
|||||||
jpeg_finish_compress(&cinfo);
|
jpeg_finish_compress(&cinfo);
|
||||||
jpeg_destroy_compress(&cinfo);
|
jpeg_destroy_compress(&cinfo);
|
||||||
fclose(fd);
|
fclose(fd);
|
||||||
TIMER_STOP(filename.c_str());
|
TIMER_STOP(("[CScreenShot::SaveJpg] " + filename).c_str());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -340,7 +382,7 @@ bool CScreenShot::SaveBmp()
|
|||||||
fwrite(pixel_data+(y*xres*4),xres*4,1,fd);
|
fwrite(pixel_data+(y*xres*4),xres*4,1,fd);
|
||||||
}
|
}
|
||||||
fclose(fd);
|
fclose(fd);
|
||||||
TIMER_STOP(filename.c_str());
|
TIMER_STOP(("[CScreenShot::SaveBmp] " + filename).c_str());
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -2,6 +2,7 @@
|
|||||||
Neutrino-GUI - DBoxII-Project
|
Neutrino-GUI - DBoxII-Project
|
||||||
|
|
||||||
Copyright (C) 2011 CoolStream International Ltd
|
Copyright (C) 2011 CoolStream International Ltd
|
||||||
|
Copyright (C) 2017 M. Liebmann (micha-bbg)
|
||||||
|
|
||||||
License: GPLv2
|
License: GPLv2
|
||||||
|
|
||||||
@@ -22,9 +23,9 @@
|
|||||||
#ifndef __screenshot_h_
|
#ifndef __screenshot_h_
|
||||||
#define __screenshot_h_
|
#define __screenshot_h_
|
||||||
|
|
||||||
#include <OpenThreads/Thread>
|
#include <pthread.h>
|
||||||
|
|
||||||
class CScreenShot : public OpenThreads::Thread
|
class CScreenShot
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
typedef enum {
|
typedef enum {
|
||||||
@@ -43,6 +44,9 @@ class CScreenShot : public OpenThreads::Thread
|
|||||||
bool get_video;
|
bool get_video;
|
||||||
bool scale_to_video;
|
bool scale_to_video;
|
||||||
FILE *fd;
|
FILE *fd;
|
||||||
|
pthread_t scs_thread;
|
||||||
|
pthread_mutex_t thread_mutex;
|
||||||
|
pthread_mutex_t getData_mutex;
|
||||||
|
|
||||||
bool GetData();
|
bool GetData();
|
||||||
bool OpenFile();
|
bool OpenFile();
|
||||||
@@ -51,7 +55,11 @@ class CScreenShot : public OpenThreads::Thread
|
|||||||
bool SavePng();
|
bool SavePng();
|
||||||
bool SaveJpg();
|
bool SaveJpg();
|
||||||
bool SaveBmp();
|
bool SaveBmp();
|
||||||
void run();
|
|
||||||
|
bool startThread();
|
||||||
|
static void* initThread(void *arg);
|
||||||
|
void runThread();
|
||||||
|
static void cleanupThread(void *arg);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CScreenShot(const std::string fname = "", screenshot_format_t fmt = CScreenShot::FORMAT_JPG);
|
CScreenShot(const std::string fname = "", screenshot_format_t fmt = CScreenShot::FORMAT_JPG);
|
||||||
|
Reference in New Issue
Block a user