X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=grpc-proxy%2Fshell.cpp;h=7267d709788a567bf06fe84a86925d36af68b821;hb=ec6f2d31293d8680a1f6dab8f53949b848bbae08;hp=34f6d375e1ada6246b64f22e62bb11ae0340a90d;hpb=4a1684308bd6a17c5b112d30e672c40fd348fef3;p=src%2Fagl-compositor.git diff --git a/grpc-proxy/shell.cpp b/grpc-proxy/shell.cpp index 34f6d37..7267d70 100644 --- a/grpc-proxy/shell.cpp +++ b/grpc-proxy/shell.cpp @@ -112,7 +112,7 @@ Shell::SetAppOnOutput(const std::string &app_id, const std::string &output) } if (!w_output) { - LOG("Could not found output '%s' to set the application\n"); + LOG("Could not found output '%s' to set the application\n", output.c_str()); return; } @@ -121,8 +121,47 @@ Shell::SetAppOnOutput(const std::string &app_id, const std::string &output) } void -Shell::SetAppSplit(const std::string &app_id, uint32_t orientation) +Shell::SetAppPosition(const std::string &app_id, const int32_t x, const int32_t y) { - (void) app_id; - (void) orientation; + struct agl_shell *shell = this->m_shell.get(); + + agl_shell_set_app_position(shell, app_id.c_str(), x, y); + wl_display_flush(m_shell_data->wl_display); +} + +void +Shell::SetAppScale(const std::string &app_id, + const int32_t width, const int32_t height) +{ + struct agl_shell *shell = this->m_shell.get(); + + agl_shell_set_app_scale(shell, app_id.c_str(), width, height); + wl_display_flush(m_shell_data->wl_display); +} + +void +Shell::SetAppSplit(const std::string &app_id, uint32_t orientation, + uint32_t width, uint32_t sticky, const std::string &output_name) +{ + struct window_output *woutput, *w_output; + struct agl_shell *shell = this->m_shell.get(); + + woutput = nullptr; + w_output = nullptr; + + wl_list_for_each(woutput, &m_shell_data->output_list, link) { + if (woutput->name && !strcmp(woutput->name, output_name.c_str())) { + w_output = woutput; + break; + } + } + + // else, get the first one available + if (!w_output) + w_output = wl_container_of(m_shell_data->output_list.prev, + w_output, link); + + + agl_shell_set_app_split(shell, app_id.c_str(), orientation, width, sticky, w_output->output); + wl_display_flush(m_shell_data->wl_display); }