mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-15 03:15:24 +00:00
c/main: Trigger the display refresh rate change request via android API ANativeWindow_setFrameRate
Part-of: <https://gitlab.freedesktop.org/monado/monado/-/merge_requests/1786>
This commit is contained in:
parent
00b491d11a
commit
7e9c6135be
|
@ -85,6 +85,7 @@
|
||||||
#ifdef XRT_OS_ANDROID
|
#ifdef XRT_OS_ANDROID
|
||||||
#include "android/android_custom_surface.h"
|
#include "android/android_custom_surface.h"
|
||||||
#include "android/android_globals.h"
|
#include "android/android_globals.h"
|
||||||
|
#include <dlfcn.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define WINDOW_TITLE "Monado"
|
#define WINDOW_TITLE "Monado"
|
||||||
|
@ -327,10 +328,15 @@ compositor_layer_commit(struct xrt_compositor *xc, xrt_graphics_sync_handle_t sy
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
compositor_get_display_refresh_rate(struct xrt_compositor *xc, float *out_display_refresh_rate_hz)
|
compositor_get_display_refresh_rate(struct xrt_compositor *xc, float *out_display_refresh_rate_hz)
|
||||||
{
|
{
|
||||||
|
#ifdef XRT_OS_ANDROID
|
||||||
|
*out_display_refresh_rate_hz =
|
||||||
|
android_custom_surface_get_display_refresh_rate(android_globals_get_vm(), android_globals_get_context());
|
||||||
|
#else
|
||||||
struct comp_compositor *c = comp_compositor(xc);
|
struct comp_compositor *c = comp_compositor(xc);
|
||||||
|
|
||||||
//! @todo: Implement the method to change display refresh rate.
|
//! @todo: Implement the method to change display refresh rate.
|
||||||
*out_display_refresh_rate_hz = (float)(1. / time_ns_to_s(c->settings.nominal_frame_interval_ns));
|
*out_display_refresh_rate_hz = (float)(1. / time_ns_to_s(c->settings.nominal_frame_interval_ns));
|
||||||
|
#endif
|
||||||
|
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -338,7 +344,26 @@ compositor_get_display_refresh_rate(struct xrt_compositor *xc, float *out_displa
|
||||||
static xrt_result_t
|
static xrt_result_t
|
||||||
compositor_request_display_refresh_rate(struct xrt_compositor *xc, float display_refresh_rate_hz)
|
compositor_request_display_refresh_rate(struct xrt_compositor *xc, float display_refresh_rate_hz)
|
||||||
{
|
{
|
||||||
//! @todo: Implement the method to change display refresh rate.
|
#ifdef XRT_OS_ANDROID
|
||||||
|
typedef int32_t (*PF_SETFRAMERATE)(ANativeWindow * window, float frameRate, int8_t compatibility);
|
||||||
|
|
||||||
|
// Note that this will just increment the reference count, rather than actually load it again,
|
||||||
|
// since we are linked for other symbols too.
|
||||||
|
void *android_handle = dlopen("libandroid.so", RTLD_NOW);
|
||||||
|
PF_SETFRAMERATE set_frame_rate = (PF_SETFRAMERATE)dlsym(android_handle, "ANativeWindow_setFrameRate");
|
||||||
|
if (!set_frame_rate) {
|
||||||
|
U_LOG_E("ANativeWindow_setFrameRate not found");
|
||||||
|
dlclose(android_handle);
|
||||||
|
return XRT_SUCCESS;
|
||||||
|
}
|
||||||
|
struct ANativeWindow *window = (struct ANativeWindow *)android_globals_get_window();
|
||||||
|
if (window == NULL || (set_frame_rate(window, display_refresh_rate_hz, 1) != 0)) {
|
||||||
|
U_LOG_E("set_frame_rate error");
|
||||||
|
}
|
||||||
|
dlclose(android_handle);
|
||||||
|
#else
|
||||||
|
// Currently not implemented on other platforms.
|
||||||
|
#endif
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -170,6 +170,7 @@ comp_window_android_init_swapchain(struct comp_target *ct, uint32_t width, uint3
|
||||||
COMP_ERROR(cwa->base.base.c, "could not get ANativeWindow");
|
COMP_ERROR(cwa->base.base.c, "could not get ANativeWindow");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
android_globals_store_window((struct _ANativeWindow *)window);
|
||||||
|
|
||||||
ret = comp_window_android_create_surface(cwa, window, &cwa->base.surface.handle);
|
ret = comp_window_android_create_surface(cwa, window, &cwa->base.surface.handle);
|
||||||
if (ret != VK_SUCCESS) {
|
if (ret != VK_SUCCESS) {
|
||||||
|
|
Loading…
Reference in a new issue