forked from Dniel97/segatools
hooklib/gfx.c: Wire up gfx config
This commit is contained in:
parent
871b82a8ad
commit
7c721aa1f8
@ -7,6 +7,8 @@
|
||||
|
||||
#include "chunihook/config.h"
|
||||
|
||||
#include "hooklib/config.h"
|
||||
|
||||
#include "platform/config.h"
|
||||
|
||||
void chuni_hook_config_load(
|
||||
@ -20,4 +22,5 @@ void chuni_hook_config_load(
|
||||
|
||||
nu_config_load(&cfg->nu, filename);
|
||||
amex_config_load(&cfg->amex, filename);
|
||||
gfx_config_load(&cfg->gfx, filename);
|
||||
}
|
||||
|
@ -4,11 +4,14 @@
|
||||
|
||||
#include "amex/config.h"
|
||||
|
||||
#include "hooklib/config.h"
|
||||
|
||||
#include "platform/config.h"
|
||||
|
||||
struct chuni_hook_config {
|
||||
struct nu_config nu;
|
||||
struct amex_config amex;
|
||||
struct gfx_config gfx;
|
||||
};
|
||||
|
||||
void chuni_hook_config_load(
|
||||
|
@ -47,7 +47,7 @@ static DWORD CALLBACK chuni_pre_startup(void)
|
||||
|
||||
/* Hook Win32 APIs */
|
||||
|
||||
gfx_hook_init();
|
||||
gfx_hook_init(&chuni_hook_cfg.gfx);
|
||||
serial_hook_init();
|
||||
|
||||
/* Initialize emulation hooks */
|
||||
@ -64,7 +64,6 @@ static DWORD CALLBACK chuni_pre_startup(void)
|
||||
/* Initialize debug helpers */
|
||||
|
||||
spike_hook_init(L".\\segatools.ini");
|
||||
gfx_set_windowed();
|
||||
|
||||
dprintf("--- End chuni_pre_startup ---\n");
|
||||
|
||||
|
@ -1,12 +1,14 @@
|
||||
#include <windows.h>
|
||||
#include <d3d9.h>
|
||||
|
||||
#include <assert.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "hook/com-proxy.h"
|
||||
#include "hook/table.h"
|
||||
|
||||
#include "hooklib/config.h"
|
||||
#include "hooklib/gfx.h"
|
||||
|
||||
#include "util/dprintf.h"
|
||||
@ -19,12 +21,10 @@ static HRESULT STDMETHODCALLTYPE my_CreateDevice(
|
||||
DWORD flags,
|
||||
D3DPRESENT_PARAMETERS *pp,
|
||||
IDirect3DDevice9 **pdev);
|
||||
|
||||
static IDirect3D9 * WINAPI my_Direct3DCreate9(UINT sdk_ver);
|
||||
|
||||
static IDirect3D9 * (WINAPI *next_Direct3DCreate9)(UINT sdk_ver);
|
||||
|
||||
static bool gfx_windowed;
|
||||
static struct gfx_config gfx_config;
|
||||
|
||||
static const struct hook_symbol gfx_hooks[] = {
|
||||
{
|
||||
@ -34,14 +34,16 @@ static const struct hook_symbol gfx_hooks[] = {
|
||||
},
|
||||
};
|
||||
|
||||
void gfx_hook_init(void)
|
||||
void gfx_hook_init(const struct gfx_config *cfg)
|
||||
{
|
||||
hook_table_apply(NULL, "d3d9.dll", gfx_hooks, _countof(gfx_hooks));
|
||||
assert(cfg != NULL);
|
||||
|
||||
if (!cfg->enable) {
|
||||
return;
|
||||
}
|
||||
|
||||
void gfx_set_windowed(void)
|
||||
{
|
||||
gfx_windowed = true;
|
||||
memcpy(&gfx_config, cfg, sizeof(*cfg));
|
||||
hook_table_apply(NULL, "d3d9.dll", gfx_hooks, _countof(gfx_hooks));
|
||||
}
|
||||
|
||||
static IDirect3D9 * WINAPI my_Direct3DCreate9(UINT sdk_ver)
|
||||
@ -99,7 +101,7 @@ static HRESULT STDMETHODCALLTYPE my_CreateDevice(
|
||||
proxy = com_proxy_downcast(self);
|
||||
real = proxy->real;
|
||||
|
||||
if (gfx_windowed) {
|
||||
if (gfx_config.windowed) {
|
||||
pp->Windowed = TRUE;
|
||||
pp->FullScreen_RefreshRateInHz = 0;
|
||||
}
|
||||
|
@ -1,4 +1,5 @@
|
||||
#pragma once
|
||||
|
||||
void gfx_hook_init(void);
|
||||
void gfx_set_windowed(void);
|
||||
#include "hooklib/config.h"
|
||||
|
||||
void gfx_hook_init(const struct gfx_config *cfg);
|
||||
|
Loading…
Reference in New Issue
Block a user