Extend ShellGlobal object with more properties
* Add screen-width, screen-height, overlay-group properties * Add set_stage_input_area() function * Fix main.js to rotate DRAFT properly svn path=/trunk/; revision=6
This commit is contained in:
parent
3d0966315e
commit
2fd4c9058d
@ -6,8 +6,8 @@ function start() {
|
||||
|
||||
let message = new Clutter.Label({font_name: "Sans Bold 64px", text: "DRAFT"});
|
||||
message.set_opacity(75);
|
||||
// Not working for unclear reasons
|
||||
// message.set_rotation(Clutter.RotateAxis.Z_AXIS, - 45, 0, 0, 0);
|
||||
message.set_position(100, 100);
|
||||
global.get_overlay_group().add_actor(message);
|
||||
message.set_anchor_point_from_gravity (Clutter.Gravity.CENTER);
|
||||
message.set_rotation(Clutter.RotateAxis.Z_AXIS, - 45, 0, 0, 0);
|
||||
message.set_position(global.screen_width / 2, global.screen_height / 2);
|
||||
global.overlay_group.add_actor(message);
|
||||
}
|
||||
|
@ -83,7 +83,6 @@ static gboolean
|
||||
do_init (const char *params)
|
||||
{
|
||||
MutterPlugin *plugin = mutter_get_plugin();
|
||||
ClutterActor *overlay_group;
|
||||
GError *error = NULL;
|
||||
int status;
|
||||
const char *shell_js;
|
||||
@ -101,9 +100,6 @@ do_init (const char *params)
|
||||
}
|
||||
}
|
||||
|
||||
overlay_group = mutter_plugin_get_overlay_group (plugin);
|
||||
shell_global_set_overlay_group (shell_global_get(), overlay_group);
|
||||
|
||||
shell_js = g_getenv("GNOME_SHELL_JS");
|
||||
if (!shell_js)
|
||||
shell_js = JSDIR;
|
||||
@ -112,6 +108,8 @@ do_init (const char *params)
|
||||
plugin_state->gjs_context = gjs_context_new_with_search_path(search_path);
|
||||
g_strfreev(search_path);
|
||||
|
||||
_shell_global_set_plugin (shell_global_get(), plugin);
|
||||
|
||||
if (!gjs_context_eval (plugin_state->gjs_context,
|
||||
"const Main = imports.ui.main; Main.start();",
|
||||
-1,
|
||||
|
@ -2,13 +2,6 @@
|
||||
|
||||
#include <mutter-plugin.h>
|
||||
|
||||
void
|
||||
mutter_plugin_query_screen_size (MutterPlugin *plugin,
|
||||
int *width,
|
||||
int *height)
|
||||
{
|
||||
}
|
||||
|
||||
ClutterActor *
|
||||
mutter_plugin_get_overlay_group (MutterPlugin *plugin)
|
||||
{
|
||||
@ -20,3 +13,16 @@ mutter_plugin_get_stage (MutterPlugin *plugin)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
void
|
||||
mutter_plugin_query_screen_size (MutterPlugin *plugin,
|
||||
int *width,
|
||||
int *height)
|
||||
{
|
||||
}
|
||||
|
||||
void
|
||||
mutter_plugin_set_stage_input_area (MutterPlugin *plugin,
|
||||
gint x, gint y, gint width, gint height)
|
||||
{
|
||||
}
|
||||
|
@ -1,17 +1,76 @@
|
||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||
|
||||
#include "shell-global.h"
|
||||
|
||||
struct _ShellGlobal {
|
||||
GObject parent;
|
||||
|
||||
ClutterActor *overlay_group;
|
||||
MutterPlugin *plugin;
|
||||
};
|
||||
|
||||
struct _ShellGlobalClass {
|
||||
GObjectClass parent_class;
|
||||
};
|
||||
|
||||
enum {
|
||||
PROP_0,
|
||||
|
||||
PROP_OVERLAY_GROUP,
|
||||
PROP_SCREEN_WIDTH,
|
||||
PROP_SCREEN_HEIGHT
|
||||
};
|
||||
|
||||
G_DEFINE_TYPE(ShellGlobal, shell_global, G_TYPE_OBJECT);
|
||||
|
||||
static void
|
||||
shell_global_set_property(GObject *object,
|
||||
guint prop_id,
|
||||
const GValue *value,
|
||||
GParamSpec *pspec)
|
||||
{
|
||||
switch (prop_id)
|
||||
{
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
shell_global_get_property(GObject *object,
|
||||
guint prop_id,
|
||||
GValue *value,
|
||||
GParamSpec *pspec)
|
||||
{
|
||||
ShellGlobal *global = SHELL_GLOBAL (object);
|
||||
|
||||
switch (prop_id)
|
||||
{
|
||||
case PROP_OVERLAY_GROUP:
|
||||
g_value_set_object (value, mutter_plugin_get_overlay_group (global->plugin));
|
||||
break;
|
||||
case PROP_SCREEN_WIDTH:
|
||||
{
|
||||
int width, height;
|
||||
|
||||
mutter_plugin_query_screen_size (global->plugin, &width, &height);
|
||||
g_value_set_int (value, width);
|
||||
}
|
||||
break;
|
||||
case PROP_SCREEN_HEIGHT:
|
||||
{
|
||||
int width, height;
|
||||
|
||||
mutter_plugin_query_screen_size (global->plugin, &width, &height);
|
||||
g_value_set_int (value, height);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
shell_global_init(ShellGlobal *global)
|
||||
{
|
||||
@ -20,6 +79,33 @@ shell_global_init(ShellGlobal *global)
|
||||
static void
|
||||
shell_global_class_init (ShellGlobalClass *klass)
|
||||
{
|
||||
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
||||
|
||||
gobject_class->get_property = shell_global_get_property;
|
||||
gobject_class->set_property = shell_global_set_property;
|
||||
|
||||
g_object_class_install_property (gobject_class,
|
||||
PROP_OVERLAY_GROUP,
|
||||
g_param_spec_object ("overlay-group",
|
||||
"Overlay Group",
|
||||
"Actor holding objects that appear above the desktop contents",
|
||||
CLUTTER_TYPE_ACTOR,
|
||||
G_PARAM_READABLE));
|
||||
g_object_class_install_property (gobject_class,
|
||||
PROP_SCREEN_WIDTH,
|
||||
g_param_spec_int ("screen-width",
|
||||
"Screen Width",
|
||||
"Screen width, in pixels",
|
||||
0, G_MAXINT, 1,
|
||||
G_PARAM_READABLE));
|
||||
|
||||
g_object_class_install_property (gobject_class,
|
||||
PROP_SCREEN_HEIGHT,
|
||||
g_param_spec_int ("screen-height",
|
||||
"Screen Height",
|
||||
"Screen height, in pixels",
|
||||
0, G_MAXINT, 1,
|
||||
G_PARAM_READABLE));
|
||||
}
|
||||
|
||||
ShellGlobal *
|
||||
@ -34,25 +120,22 @@ shell_global_get (void)
|
||||
}
|
||||
|
||||
void
|
||||
shell_global_set_overlay_group (ShellGlobal *global,
|
||||
ClutterActor *overlay_group)
|
||||
shell_global_set_stage_input_area (ShellGlobal *global,
|
||||
int x,
|
||||
int y,
|
||||
int width,
|
||||
int height)
|
||||
{
|
||||
g_object_ref (overlay_group);
|
||||
g_return_if_fail (SHELL_IS_GLOBAL (global));
|
||||
|
||||
if (global->overlay_group)
|
||||
g_object_unref(global->overlay_group);
|
||||
|
||||
global->overlay_group = overlay_group;
|
||||
}
|
||||
|
||||
ClutterActor *
|
||||
shell_global_get_overlay_group (ShellGlobal *global)
|
||||
{
|
||||
return global->overlay_group;
|
||||
mutter_plugin_set_stage_input_area (global->plugin, x, y, width, height);
|
||||
}
|
||||
|
||||
void
|
||||
shell_global_print_hello (ShellGlobal *global)
|
||||
_shell_global_set_plugin (ShellGlobal *global,
|
||||
MutterPlugin *plugin)
|
||||
{
|
||||
g_print("Hello World!\n");
|
||||
g_return_if_fail (SHELL_IS_GLOBAL (global));
|
||||
|
||||
global->plugin = plugin;
|
||||
}
|
||||
|
@ -1,6 +1,7 @@
|
||||
#ifndef __SHELL_GLOBAL_H__
|
||||
#define __SHELL_GLOBAL_H__
|
||||
|
||||
#include "mutter-plugin.h"
|
||||
#include <clutter/clutter.h>
|
||||
#include <glib-object.h>
|
||||
|
||||
@ -20,12 +21,8 @@ GType shell_global_get_type (void) G_GNUC_CONST;
|
||||
|
||||
ShellGlobal *shell_global_get (void);
|
||||
|
||||
void shell_global_set_overlay_group (ShellGlobal *global,
|
||||
ClutterActor *overlay_group);
|
||||
|
||||
ClutterActor *shell_global_get_overlay_group (ShellGlobal *global);
|
||||
|
||||
void shell_global_print_hello (ShellGlobal *global);
|
||||
void _shell_global_set_plugin (ShellGlobal *global,
|
||||
MutterPlugin *plugin);
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user