ttkManager.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * Copyright (c) 2005, Joe English. Freely redistributable.
  3. *
  4. * Geometry manager utilities.
  5. */
  6. #ifndef _TTKMANAGER
  7. #define _TTKMANAGER
  8. #include "ttkTheme.h"
  9. typedef struct TtkManager_ Ttk_Manager;
  10. /*
  11. * Geometry manager specification record:
  12. *
  13. * RequestedSize computes the requested size of the container window.
  14. *
  15. * PlaceSlaves sets the position and size of all managed content windows
  16. * by calling Ttk_PlaceContent().
  17. *
  18. * SlaveRemoved() is called immediately before a content window is removed.
  19. * NB: the associated content window may have been destroyed when this
  20. * routine is called.
  21. *
  22. * SlaveRequest() is called when a content window requests a size change.
  23. * It should return 1 if the request should propagate, 0 otherwise.
  24. */
  25. typedef struct { /* Manager hooks */
  26. Tk_GeomMgr tkGeomMgr; /* "real" Tk Geometry Manager */
  27. int (*RequestedSize)(void *managerData, int *widthPtr, int *heightPtr);
  28. void (*PlaceSlaves)(void *managerData);
  29. int (*SlaveRequest)(void *managerData, int index, int w, int h);
  30. void (*SlaveRemoved)(void *managerData, int index);
  31. } Ttk_ManagerSpec;
  32. /*
  33. * Default implementations for Tk_GeomMgr hooks:
  34. */
  35. #define Ttk_LostContentProc Ttk_LostSlaveProc
  36. MODULE_SCOPE void Ttk_GeometryRequestProc(ClientData, Tk_Window window);
  37. MODULE_SCOPE void Ttk_LostContentProc(ClientData, Tk_Window window);
  38. /*
  39. * Public API:
  40. */
  41. MODULE_SCOPE Ttk_Manager *Ttk_CreateManager(
  42. Ttk_ManagerSpec *, void *managerData, Tk_Window window);
  43. MODULE_SCOPE void Ttk_DeleteManager(Ttk_Manager *);
  44. #define Ttk_InsertContent Ttk_InsertSlave
  45. MODULE_SCOPE void Ttk_InsertContent(
  46. Ttk_Manager *, int position, Tk_Window, void *data);
  47. #define Ttk_ForgetContent Ttk_ForgetSlave
  48. MODULE_SCOPE void Ttk_ForgetContent(Ttk_Manager *, int index);
  49. #define Ttk_ReorderContent Ttk_ReorderSlave
  50. MODULE_SCOPE void Ttk_ReorderContent(Ttk_Manager *, int fromIndex, int toIndex);
  51. /* Rearrange content window positions */
  52. #define Ttk_PlaceContent Ttk_PlaceSlave
  53. MODULE_SCOPE void Ttk_PlaceContent(
  54. Ttk_Manager *, int index, int x, int y, int width, int height);
  55. /* Position and map the content window */
  56. #define Ttk_UnmapContent Ttk_UnmapSlave
  57. MODULE_SCOPE void Ttk_UnmapContent(Ttk_Manager *, int index);
  58. /* Unmap the content window */
  59. MODULE_SCOPE void Ttk_ManagerSizeChanged(Ttk_Manager *);
  60. MODULE_SCOPE void Ttk_ManagerLayoutChanged(Ttk_Manager *);
  61. /* Notify manager that size (resp. layout) needs to be recomputed */
  62. /* Utilities:
  63. */
  64. #define Ttk_ContentIndex Ttk_SlaveIndex
  65. MODULE_SCOPE int Ttk_ContentIndex(Ttk_Manager *, Tk_Window);
  66. /* Returns: index in content array of specified window, -1 if not found */
  67. #define Ttk_GetContentIndexFromObj Ttk_GetSlaveIndexFromObj
  68. MODULE_SCOPE int Ttk_GetContentIndexFromObj(
  69. Tcl_Interp *, Ttk_Manager *, Tcl_Obj *, int *indexPtr);
  70. /* Accessor functions:
  71. */
  72. #define Ttk_NumberContent Ttk_NumberSlaves
  73. MODULE_SCOPE int Ttk_NumberContent(Ttk_Manager *);
  74. /* Returns: number of managed content windows */
  75. #define Ttk_ContentData Ttk_SlaveData
  76. MODULE_SCOPE void *Ttk_ContentData(Ttk_Manager *, int index);
  77. /* Returns: client data associated with content window */
  78. #define Ttk_ContentWindow Ttk_SlaveWindow
  79. MODULE_SCOPE Tk_Window Ttk_ContentWindow(Ttk_Manager *, int index);
  80. /* Returns: content window */
  81. MODULE_SCOPE int Ttk_Maintainable(Tcl_Interp *, Tk_Window content, Tk_Window container);
  82. /* Returns: 1 if container can manage content; 0 otherwise leaving error msg */
  83. #endif /* _TTKMANAGER */