mirror of
https://github.com/gnif/LookingGlass.git
synced 2025-01-11 06:43:56 +00:00
[c-host] initial stubs for pointer support
This commit is contained in:
parent
40a1b860bf
commit
496fd79714
4 changed files with 39 additions and 17 deletions
|
@ -288,10 +288,7 @@ int app_main()
|
|||
}
|
||||
app.reinit = false;
|
||||
|
||||
bool frameUpdate = false;
|
||||
bool pointerUpdate = false;
|
||||
|
||||
switch(iface->capture(&frameUpdate, &pointerUpdate))
|
||||
switch(iface->capture())
|
||||
{
|
||||
case CAPTURE_RESULT_OK:
|
||||
break;
|
||||
|
|
|
@ -33,10 +33,17 @@ CaptureResult;
|
|||
|
||||
typedef enum CaptureFormat
|
||||
{
|
||||
CAPTURE_FMT_BGRA,
|
||||
CAPTURE_FMT_RGBA,
|
||||
// frame formats
|
||||
CAPTURE_FMT_BGRA ,
|
||||
CAPTURE_FMT_RGBA ,
|
||||
CAPTURE_FMT_RGBA10,
|
||||
CAPTURE_FMT_YUV420,
|
||||
|
||||
// pointer formats
|
||||
CAPTURE_FMT_COLOR ,
|
||||
CAPTURE_FMT_MONO ,
|
||||
CAPTURE_FMT_MASKED,
|
||||
|
||||
CAPTURE_FMT_MAX
|
||||
}
|
||||
CaptureFormat;
|
||||
|
@ -52,6 +59,16 @@ typedef struct CaptureFrame
|
|||
}
|
||||
CaptureFrame;
|
||||
|
||||
typedef struct CapturePointer
|
||||
{
|
||||
int x, y;
|
||||
CaptureFormat format;
|
||||
unsigned int width, height;
|
||||
unsigned int pitch;
|
||||
void * data;
|
||||
}
|
||||
CapturePointer;
|
||||
|
||||
typedef struct CaptureInterface
|
||||
{
|
||||
const char * (*getName )();
|
||||
|
@ -61,10 +78,9 @@ typedef struct CaptureInterface
|
|||
void (*free )();
|
||||
unsigned int (*getMaxFrameSize)();
|
||||
|
||||
CaptureResult (*capture)(
|
||||
bool * hasFrameUpdate,
|
||||
bool * hasPointerUpdate);
|
||||
CaptureResult (*capture)();
|
||||
|
||||
bool (*getFrame)(CaptureFrame * frame);
|
||||
bool (*getFrame )(CaptureFrame * frame );
|
||||
bool (*getPointer)(CapturePointer * pointer);
|
||||
}
|
||||
CaptureInterface;
|
|
@ -168,7 +168,7 @@ static unsigned int xcb_getMaxFrameSize()
|
|||
return this->width * this->height * 4;
|
||||
}
|
||||
|
||||
static CaptureResult xcb_capture(bool * hasFrameUpdate, bool * hasPointerUpdate)
|
||||
static CaptureResult xcb_capture()
|
||||
{
|
||||
assert(this);
|
||||
assert(this->initialized);
|
||||
|
@ -186,7 +186,6 @@ static CaptureResult xcb_capture(bool * hasFrameUpdate, bool * hasPointerUpdate)
|
|||
this->seg,
|
||||
0);
|
||||
|
||||
*hasFrameUpdate = true;
|
||||
this->hasFrame = true;
|
||||
os_signalEvent(this->frameEvent);
|
||||
}
|
||||
|
@ -223,6 +222,11 @@ static bool xcb_getFrame(CaptureFrame * frame)
|
|||
return true;
|
||||
}
|
||||
|
||||
static bool xcb_getPointer(CapturePointer * pointer)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
struct CaptureInterface Capture_XCB =
|
||||
{
|
||||
.getName = xcb_getName,
|
||||
|
@ -232,5 +236,6 @@ struct CaptureInterface Capture_XCB =
|
|||
.free = xcb_free,
|
||||
.getMaxFrameSize = xcb_getMaxFrameSize,
|
||||
.capture = xcb_capture,
|
||||
.getFrame = xcb_getFrame
|
||||
.getFrame = xcb_getFrame,
|
||||
.getPointer = xcb_getPointer
|
||||
};
|
|
@ -472,7 +472,7 @@ static unsigned int dxgi_getMaxFrameSize()
|
|||
return this->height * this->pitch;
|
||||
}
|
||||
|
||||
inline static CaptureResult dxgi_capture_int(bool * hasFrameUpdate, bool * hasPointerUpdate)
|
||||
inline static CaptureResult dxgi_capture_int()
|
||||
{
|
||||
assert(this);
|
||||
assert(this->initialized);
|
||||
|
@ -553,14 +553,12 @@ inline static CaptureResult dxgi_capture_int(bool * hasFrameUpdate, bool * hasPo
|
|||
this->texWIndex = 0;
|
||||
|
||||
ID3D11Texture2D_Release(src);
|
||||
*hasFrameUpdate = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (frameInfo.PointerShapeBufferSize > 0)
|
||||
{
|
||||
os_signalEvent(this->pointerEvent);
|
||||
*hasPointerUpdate = true;
|
||||
}
|
||||
|
||||
IDXGIResource_Release(res);
|
||||
|
@ -615,6 +613,11 @@ static bool dxgi_getFrame(CaptureFrame * frame)
|
|||
return true;
|
||||
}
|
||||
|
||||
static bool dxgi_getPointer(CapturePointer * pointer)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
static CaptureResult dxgi_releaseFrame()
|
||||
{
|
||||
assert(this);
|
||||
|
@ -656,5 +659,6 @@ struct CaptureInterface Capture_DXGI =
|
|||
.free = dxgi_free,
|
||||
.getMaxFrameSize = dxgi_getMaxFrameSize,
|
||||
.capture = dxgi_capture,
|
||||
.getFrame = dxgi_getFrame
|
||||
.getFrame = dxgi_getFrame,
|
||||
.getPointer = dxgi_getPointer
|
||||
};
|
Loading…
Reference in a new issue