diff --git a/idl/gepetto/viewer/graphical-interface.idl b/idl/gepetto/viewer/graphical-interface.idl
index 9755616fa0f016b3ed115c8c5dbfee696befad24..9b8d63ddbdbaae208a372fb6b899ae8dc4147e7b 100644
--- a/idl/gepetto/viewer/graphical-interface.idl
+++ b/idl/gepetto/viewer/graphical-interface.idl
@@ -21,7 +21,7 @@ typedef float Transform [7];
 typedef float Vector2 [2];
 typedef float Position [3];
 typedef float Color [4];
-typedef unsigned long WindowID;
+typedef string WindowID;
 typedef sequence <string> Names_t; /// Sequence of names
 typedef sequence<float> floatSeq;
 typedef sequence<Position> PositionSeq;
@@ -49,18 +49,18 @@ typedef sequence<Transform> TransformSeq;
     /// Create a new window.
     /// \param input name : name of the new window.
     /// return the ID of the newly create window.
-    unsigned long createWindow(in string name) raises (Error);
-    unsigned long getWindowID (in string name) raises (Error);
+    WindowID createWindow(in string name) raises (Error);
+    WindowID getWindowID (in string name) raises (Error);
     
     /// change the background color1
-    /// \param input windowId : ID of the window
+    /// \param input wid : ID of the window
     /// \param input RGBAcolor : desired color
-    boolean setBackgroundColor1(in unsigned long windowId,in Color RGBAcolor);
+    boolean setBackgroundColor1(in WindowID wid,in Color RGBAcolor);
     
     /// change the background color2
-    /// \param input windowId : ID of the window
+    /// \param input wid : ID of the window
     /// \param input RGBAcolor : desired color
-    boolean setBackgroundColor2(in unsigned long windowId,in Color RGBAcolor);
+    boolean setBackgroundColor2(in WindowID wid,in Color RGBAcolor);
 
     /// Create a group node.
     /// \param input sceneName : name of the group.
@@ -73,8 +73,8 @@ typedef sequence<Transform> TransformSeq;
     /// Add groupNode sceneName to the WindowManager windowName so
     /// sceneName and all its children will be displayed in the window windowName.
     /// \param input sceneName : name of the groupNode.
-    /// \param input windowId : ID of rhe window.
-    boolean addSceneToWindow(in string sceneName, in unsigned long windowId) raises (Error);
+    /// \param input wid : ID of rhe window.
+    boolean addSceneToWindow(in string sceneName, in WindowID wid) raises (Error);
 
     /// \}
 
@@ -445,7 +445,7 @@ typedef sequence<Transform> TransformSeq;
     void captureFrame (in WindowID wid, in string imageFilename) raises (Error);
 
     /// Start capturing a window into image files.
-    /// \param windowId the ID of the window
+    /// \param wid the ID of the window
     /// \param filename, extension image files will be
     /// '<filename>_<sequence_number>.<extension>'
     ///
@@ -457,11 +457,11 @@ typedef sequence<Transform> TransformSeq;
     /// - \c libx264 is not installed by default. On ubuntu 12.04,
     ///   it is part of the package \c libavcodec-extra-53.
     /// - \c yuv420p is required only to enable support for old media players.
-    boolean startCapture (in unsigned long windowId, in string filename,
+    boolean startCapture (in WindowID wid, in string filename,
       in string extension) raises (Error);
 
     /// Stop the running capture of a window.
-    boolean stopCapture (in unsigned long windowId) raises (Error);
+    boolean stopCapture (in WindowID wid) raises (Error);
 
     /// Configure the capture of node transformation in YAML format
     /// \param filename file where to write.
@@ -486,7 +486,7 @@ typedef sequence<Transform> TransformSeq;
     boolean writeNodeFile (in string nodeName, in string filename) raises (Error);
 
     /// Write the nodes contained in the window to filename
-    boolean writeWindowFile (in unsigned long windowId, in string filename) raises (Error);
+    boolean writeWindowFile (in WindowID wid, in string filename) raises (Error);
 
     /// \}
 
@@ -495,31 +495,31 @@ typedef sequence<Transform> TransformSeq;
     /// \{
 
     /// Attach the camera to the Node nodeName in the WindowManager
-    /// pointed by windowId
+    /// pointed by wid
     /// If already attached, detach from the other node
     /// \param input nodeName : name of the node
-    /// \param input windowId : ID of the window
-    boolean attachCameraToNode(in string nodeName, in unsigned long windowId) raises (Error);
+    /// \param input wid : ID of the window
+    boolean attachCameraToNode(in string nodeName, in WindowID wid) raises (Error);
 
-    /// Detach the camera of WindowManager pointed by windowId
+    /// Detach the camera of WindowManager pointed by wid
     /// from any node
-    /// \param input windowId : ID of the window
-    boolean detachCamera(in unsigned long windowId) raises (Error);
+    /// \param input wid : ID of the window
+    boolean detachCamera(in WindowID wid) raises (Error);
 
     /// get the matrix transform of the current position of the camera
     /// Camera frame convention (OpenSceneGraph): looking through the optic axis as a photographer,
     /// axis are: X -> right, Y -> up, Z -> behind
     /// It corresponds to Hartley and Zisserman's frame convention with a 180° rotation around the Y axis
-    /// \param input windowId : ID of the window
-    Transform getCameraTransform(in unsigned long windowId) raises (Error);
+    /// \param input wid : ID of the window
+    Transform getCameraTransform(in WindowID wid) raises (Error);
 
     /// set the matrix transform of the current camera
     /// Camera frame convention (OpenSceneGraph): looking through the optic axis as a photographer,
     /// axis are: X -> right, Y -> up, Z -> behind
     /// It corresponds to Hartley and Zisserman's frame convention with a 180° rotation around the Y axis
-    /// \param input windowId : ID of the window
+    /// \param input wid : ID of the window
     /// \param input configuration : the desired configuration of the camera
-    boolean setCameraTransform(in unsigned long windowId,in Transform configuration) raises (Error);
+    boolean setCameraTransform(in WindowID wid, in Transform configuration) raises (Error);
 
     // register a Node callback
     boolean registerNodeCallback (in NodeCallback cb) raises (Error);
diff --git a/src/conversions.hh b/src/conversions.hh
index 82a4738f3d54ea4833c99bb4ce4729deeea8c2da..8f6f419d99b040510733aa612f722682b1bc0dc0 100644
--- a/src/conversions.hh
+++ b/src/conversions.hh
@@ -12,8 +12,6 @@ namespace gepetto {
   namespace viewer {
   namespace corba {
     namespace impl {
-        typedef GraphicalInterface::WindowID WindowID;
-
         template <typename Input, typename Output>
           void to (const Input& in, Output& out) {
             for (CORBA::ULong i = 0; i < in.length(); ++i)
@@ -44,8 +42,8 @@ namespace gepetto {
 
         enum ArgType { STRING, STRING_LIST, OUT_STRING_LIST, COLOR,
           TRANSFORM, TRANSFORM_SEQ, POSITION, POSITION_SEQ,
-          FLOAT, SHORT, LONG, WINDOW_ID, BOOL, VOID,
-          GLMODE, VECTOR2
+          FLOAT, SHORT, LONG, BOOL, VOID,
+          GLMODE, VECTOR2, WINDOW_ID = STRING
         };
 
         template <int what> struct traits {};
@@ -138,13 +136,6 @@ namespace gepetto {
           static int op (const In_t& in) { return in; }
           static Ret_t ret (Out_t  in) { return in; }
         };
-        template <> struct traits<WINDOW_ID> {
-          typedef       WindowsManager::WindowID  Out_t;
-          typedef const WindowID  In_t;
-          typedef       WindowID  Ret_t;
-          static Out_t op  (In_t & in) { return in; }
-          static Ret_t ret (Out_t  in) { return in; }
-        };
         template <> struct traits<BOOL> {
           typedef bool In_t;
           typedef In_t Out_t;
diff --git a/src/graphical-interface.impl.hh b/src/graphical-interface.impl.hh
index e3014ad80c48d6f9d0cd78ae6339f5c06d8b7453..407a8a43b844da6934aaf2243055ef9724d54b6e 100644
--- a/src/graphical-interface.impl.hh
+++ b/src/graphical-interface.impl.hh
@@ -30,8 +30,6 @@ private:
     typedef gepetto::gui::WindowsManager::value_type value_type;
 
 public:
-    typedef CORBA::ULong WindowID;
-
     /**
         \brief Default constructor
         */
@@ -50,15 +48,15 @@ public:
   virtual void refresh();
   virtual void setRefreshIsSynchronous(bool synchronous);
 
-  virtual WindowID createWindow(const char* windowNameCorba);
-  virtual WindowID getWindowID (const char* windowNameCorba);
+  virtual char* createWindow(const char* windowNameCorba);
+  virtual char* getWindowID (const char* windowNameCorba);
 
   virtual void createScene(const char* sceneNameCorba);
   virtual void createSceneWithFloor(const char* sceneNameCorba);
-  virtual bool addSceneToWindow(const char* sceneNameCorba, const WindowID windowId);
+  virtual bool addSceneToWindow(const char* sceneNameCorba, const char* windowId);
 
-  virtual bool attachCameraToNode(const char* nodeName, const WindowID windowId);
-  virtual bool detachCamera(const WindowID windowId);
+  virtual bool attachCameraToNode(const char* nodeName, const char* windowId);
+  virtual bool detachCamera(const char* windowId);
 
   virtual bool nodeExists(const char* nodeName);
 
@@ -86,7 +84,7 @@ public:
 
   virtual bool addSphere(const char* sphereName, float radius, const Color color);
 
-  virtual bool addLight(const char* lightName, const WindowID windowId, float radius, const Color color);
+  virtual bool addLight(const char* lightName, const char* windowId, float radius, const Color color);
 
   virtual bool addLine(const char* lineName, const value_type* pos1, const value_type* pos2, const Color color);
   virtual bool setLineStartPoint(const char* lineName, const value_type* pos1);
@@ -142,23 +140,23 @@ public:
   virtual bool setLightingMode(const char* nodeNameCorba, const char* lightingModeCorba);
   virtual bool setHighlight(const char* nodeNameCorba, ::CORBA::Long state);
 
-  virtual void captureFrame (const WindowID windowId, const char* filename);
-  virtual bool startCapture (const WindowID windowId, const char* filename,
+  virtual void captureFrame (const char* windowId, const char* filename);
+  virtual bool startCapture (const char* windowId, const char* filename,
       const char* extension);
-  virtual bool stopCapture (const WindowID windowId);
+  virtual bool stopCapture (const char* windowId);
   virtual bool setCaptureTransform (const char* filename, const Names_t& nodename);
   virtual void captureTransformOnRefresh (bool autoCapture);
   virtual void captureTransform ();
   virtual bool writeBlenderScript (const char* filename, const Names_t& nodeNames);
   virtual bool writeNodeFile (const char* nodename, const char* filename);
-  virtual bool writeWindowFile (const WindowID windowId, const char* filename);
+  virtual bool writeWindowFile (const char* windowId, const char* filename);
 
   virtual Transform_slice* getNodeGlobalTransform(const char* nodeName);
   virtual void deleteNode (const char* nodeName, bool all);
-  virtual bool setBackgroundColor1(const WindowID windowId,const Color colorCorba);
-  virtual bool setBackgroundColor2(const WindowID windowId,const Color colorCorba);
-  virtual Transform_slice* getCameraTransform(const WindowID windowId);
-  virtual bool setCameraTransform(const WindowID windowId, const value_type *configurationCorba);
+  virtual bool setBackgroundColor1(const char* windowId,const Color colorCorba);
+  virtual bool setBackgroundColor2(const char* windowId,const Color colorCorba);
+  virtual Transform_slice* getCameraTransform(const char* windowId);
+  virtual bool setCameraTransform(const char* windowId, const value_type *configurationCorba);
 
   // ------------- Properties -------------------- //
   virtual Names_t* getPropertyNames(const char* nodeName);