亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? gdkwindow-x11.c

?? linux下電話本所依賴的一些圖形庫
?? C
?? 第 1 頁 / 共 5 頁
字號:
}static GdkEventMaskx_event_mask_to_gdk_event_mask (long mask){  GdkEventMask event_mask = 0;  int i;  for (i = 0; i < _gdk_nenvent_masks; i++)    {      if (mask & _gdk_event_mask_table[i])	event_mask |= 1 << (i + 1);    }  return event_mask;}/** * gdk_window_foreign_new_for_display: * @display: the #GdkDisplay where the window handle comes from. * @anid: a native window handle. *  * Wraps a native window in a #GdkWindow. * This may fail if the window has been destroyed. If the window * was already known to GDK, a new reference to the existing  * #GdkWindow is returned. * * For example in the X backend, a native window handle is an Xlib * <type>XID</type>. *  * Return value: a #GdkWindow wrapper for the native window or  *   %NULL if the window has been destroyed. The wrapper will be *   newly created, if one doesn't exist already. * * Since: 2.2 **/GdkWindow *gdk_window_foreign_new_for_display (GdkDisplay     *display,				    GdkNativeWindow anid){  GdkWindow *window;  GdkWindowObject *private;  GdkWindowImplX11 *impl;  GdkDrawableImplX11 *draw_impl;  GdkDisplayX11 *display_x11;  XWindowAttributes attrs;  Window root, parent;  Window *children = NULL;  guint nchildren;  gboolean result;  g_return_val_if_fail (GDK_IS_DISPLAY (display), NULL);  display_x11 = GDK_DISPLAY_X11 (display);  if ((window = gdk_xid_table_lookup_for_display (display, anid)) != NULL)    return g_object_ref (window);  gdk_error_trap_push ();  result = XGetWindowAttributes (display_x11->xdisplay, anid, &attrs);  if (gdk_error_trap_pop () || !result)    return NULL;  /* FIXME: This is pretty expensive. Maybe the caller should supply   *        the parent */  gdk_error_trap_push ();  result = XQueryTree (display_x11->xdisplay, anid, &root, &parent, &children, &nchildren);  if (gdk_error_trap_pop () || !result)    return NULL;  if (children)    XFree (children);    window = g_object_new (GDK_TYPE_WINDOW, NULL);  private = (GdkWindowObject *)window;  impl = GDK_WINDOW_IMPL_X11 (private->impl);  draw_impl = GDK_DRAWABLE_IMPL_X11 (private->impl);  draw_impl->wrapper = GDK_DRAWABLE (window);  draw_impl->screen = _gdk_x11_display_screen_for_xrootwin (display, root);    private->parent = gdk_xid_table_lookup_for_display (display, parent);    if (!private->parent || GDK_WINDOW_TYPE (private->parent) == GDK_WINDOW_FOREIGN)    private->parent = (GdkWindowObject *) gdk_screen_get_root_window (draw_impl->screen);    private->parent->children = g_list_prepend (private->parent->children, window);  draw_impl->xid = anid;  private->x = attrs.x;  private->y = attrs.y;  impl->width = attrs.width;  impl->height = attrs.height;  private->window_type = GDK_WINDOW_FOREIGN;  private->destroyed = FALSE;  private->event_mask = x_event_mask_to_gdk_event_mask (attrs.your_event_mask);  if (attrs.map_state == IsUnmapped)    private->state = GDK_WINDOW_STATE_WITHDRAWN;  else    private->state = 0;  private->depth = attrs.depth;    _gdk_window_init_position (GDK_WINDOW (private));  g_object_ref (window);  _gdk_xid_table_insert (display, &GDK_WINDOW_XID (window), window);  return window;}/** * gdk_window_lookup_for_display: * @display: the #GdkDisplay corresponding to the window handle * @anid: a native window handle. * * Looks up the #GdkWindow that wraps the given native window handle. * * For example in the X backend, a native window handle is an Xlib * <type>XID</type>. * * Return value: the #GdkWindow wrapper for the native window,  *    or %NULL if there is none. * * Since: 2.2 **/GdkWindow *gdk_window_lookup_for_display (GdkDisplay *display, GdkNativeWindow anid){  return (GdkWindow*) gdk_xid_table_lookup_for_display (display, anid);}/** * gdk_window_lookup: * @anid: a native window handle. * * Looks up the #GdkWindow that wraps the given native window handle.  * * For example in the X backend, a native window handle is an Xlib * <type>XID</type>. * * Return value: the #GdkWindow wrapper for the native window,  *    or %NULL if there is none. **/GdkWindow *gdk_window_lookup (GdkNativeWindow anid){  return (GdkWindow*) gdk_xid_table_lookup (anid);}static voidgdk_toplevel_x11_free_contents (GdkDisplay *display,				GdkToplevelX11 *toplevel){  if (toplevel->icon_window)    {      g_object_unref (toplevel->icon_window);      toplevel->icon_window = NULL;    }  if (toplevel->icon_pixmap)    {      g_object_unref (toplevel->icon_pixmap);      toplevel->icon_pixmap = NULL;    }  if (toplevel->icon_mask)    {      g_object_unref (toplevel->icon_mask);      toplevel->icon_mask = NULL;    }  if (toplevel->group_leader)    {      g_object_unref (toplevel->group_leader);      toplevel->group_leader = NULL;    }#ifdef HAVE_XSYNC  if (toplevel->update_counter != None)    {      XSyncDestroyCounter (GDK_DISPLAY_XDISPLAY (display), 			   toplevel->update_counter);      toplevel->update_counter = None;      XSyncIntToValue (&toplevel->current_counter_value, 0);    }#endif}void_gdk_windowing_window_destroy (GdkWindow *window,			       gboolean   recursing,			       gboolean   foreign_destroy){  GdkWindowObject *private = (GdkWindowObject *)window;  GdkToplevelX11 *toplevel;  GdkDrawableImplX11 *draw_impl;    g_return_if_fail (GDK_IS_WINDOW (window));  _gdk_selection_window_destroyed (window);    if (private->extension_events != 0)    _gdk_input_window_destroy (window);  toplevel = _gdk_x11_window_get_toplevel (window);  if (toplevel)    gdk_toplevel_x11_free_contents (GDK_WINDOW_DISPLAY (window), toplevel);  draw_impl = GDK_DRAWABLE_IMPL_X11 (private->impl);      if (draw_impl->xft_draw)    XftDrawDestroy (draw_impl->xft_draw);  if (!recursing && !foreign_destroy)    {      XDestroyWindow (GDK_WINDOW_XDISPLAY (window), GDK_WINDOW_XID (window));    }}void_gdk_windowing_window_destroy_foreign (GdkWindow *window){  /* It's somebody else's window, but in our heirarchy,   * so reparent it to the root window, and then send   * it a delete event, as if we were a WM   */  XClientMessageEvent xevent;    gdk_error_trap_push ();  gdk_window_hide (window);  gdk_window_reparent (window, NULL, 0, 0);    xevent.type = ClientMessage;  xevent.window = GDK_WINDOW_XID (window);  xevent.message_type = gdk_x11_get_xatom_by_name_for_display (GDK_WINDOW_DISPLAY (window),							       "WM_PROTOCOLS");  xevent.format = 32;  xevent.data.l[0] = gdk_x11_get_xatom_by_name_for_display (GDK_WINDOW_DISPLAY (window),							    "WM_DELETE_WINDOW");  xevent.data.l[1] = CurrentTime;  xevent.data.l[2] = 0;  xevent.data.l[3] = 0;  xevent.data.l[4] = 0;    XSendEvent (GDK_WINDOW_XDISPLAY (window),	      GDK_WINDOW_XID (window),	      False, 0, (XEvent *)&xevent);  gdk_display_sync (GDK_WINDOW_DISPLAY (window));  gdk_error_trap_pop ();}static GdkWindow *get_root (GdkWindow *window){  GdkScreen *screen = gdk_drawable_get_screen (window);  return gdk_screen_get_root_window (screen);}/* This function is called when the XWindow is really gone. */voidgdk_window_destroy_notify (GdkWindow *window){  GdkWindowImplX11 *window_impl;  g_return_if_fail (window != NULL);    window_impl = GDK_WINDOW_IMPL_X11 (((GdkWindowObject *)window)->impl);  if (!GDK_WINDOW_DESTROYED (window))    {      if (GDK_WINDOW_TYPE(window) != GDK_WINDOW_FOREIGN)	g_warning ("GdkWindow %#lx unexpectedly destroyed", GDK_WINDOW_XID (window));      _gdk_window_destroy (window, TRUE);    }    _gdk_xid_table_remove (GDK_WINDOW_DISPLAY (window), GDK_WINDOW_XID (window));  if (window_impl->toplevel && window_impl->toplevel->focus_window)    _gdk_xid_table_remove (GDK_WINDOW_DISPLAY (window), window_impl->toplevel->focus_window);  _gdk_xgrab_check_destroy (window);    g_object_unref (window);}static voidupdate_wm_hints (GdkWindow *window,		 gboolean   force){  GdkToplevelX11 *toplevel = _gdk_x11_window_get_toplevel (window);  GdkWindowObject *private = (GdkWindowObject *)window;  GdkDisplay *display = GDK_WINDOW_DISPLAY (window);  XWMHints wm_hints;  if (!force &&      !toplevel->is_leader &&      private->state & GDK_WINDOW_STATE_WITHDRAWN)    return;  wm_hints.flags = StateHint | InputHint;  wm_hints.input = private->accept_focus ? True : False;  wm_hints.initial_state = NormalState;    if (private->state & GDK_WINDOW_STATE_ICONIFIED)    {      wm_hints.flags |= StateHint;      wm_hints.initial_state = IconicState;    }  if (toplevel->icon_window && !GDK_WINDOW_DESTROYED (toplevel->icon_window))    {      wm_hints.flags |= IconWindowHint;      wm_hints.icon_window = GDK_WINDOW_XID (toplevel->icon_window);    }  if (toplevel->icon_pixmap)    {      wm_hints.flags |= IconPixmapHint;      wm_hints.icon_pixmap = GDK_PIXMAP_XID (toplevel->icon_pixmap);    }  if (toplevel->icon_mask)    {      wm_hints.flags |= IconMaskHint;      wm_hints.icon_mask = GDK_PIXMAP_XID (toplevel->icon_mask);    }    wm_hints.flags |= WindowGroupHint;  if (toplevel->group_leader && !GDK_WINDOW_DESTROYED (toplevel->group_leader))    {      wm_hints.flags |= WindowGroupHint;      wm_hints.window_group = GDK_WINDOW_XID (toplevel->group_leader);    }  else    wm_hints.window_group = GDK_DISPLAY_X11 (display)->leader_window;    XSetWMHints (GDK_WINDOW_XDISPLAY (window),	       GDK_WINDOW_XID (window),	       &wm_hints);}static voidset_initial_hints (GdkWindow *window){  GdkDisplay *display = GDK_WINDOW_DISPLAY (window);  Display *xdisplay = GDK_DISPLAY_XDISPLAY (display);  Window xwindow = GDK_WINDOW_XID (window);    GdkWindowObject *private;  GdkToplevelX11 *toplevel;  Atom atoms[7];  gint i;  private = (GdkWindowObject*) window;  toplevel = _gdk_x11_window_get_toplevel (window);  if (!toplevel)    return;  update_wm_hints (window, TRUE);    /* We set the spec hints regardless of whether the spec is supported,   * since it can't hurt and it's kind of expensive to check whether   * it's supported.   */    i = 0;  if (private->state & GDK_WINDOW_STATE_MAXIMIZED)    {      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_MAXIMIZED_VERT");      ++i;      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_MAXIMIZED_HORZ");      ++i;    }  if (private->state & GDK_WINDOW_STATE_ABOVE)    {      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_ABOVE");      ++i;    }    if (private->state & GDK_WINDOW_STATE_BELOW)    {      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_BELOW");      ++i;    }    if (private->state & GDK_WINDOW_STATE_STICKY)    {      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_STICKY");      ++i;    }  if (private->state & GDK_WINDOW_STATE_FULLSCREEN)    {      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_FULLSCREEN");      ++i;    }  if (private->modal_hint)    {      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_MODAL");      ++i;    }  if (toplevel->skip_taskbar_hint)    {      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_SKIP_TASKBAR");      ++i;    }  if (toplevel->skip_pager_hint)    {      atoms[i] = gdk_x11_get_xatom_by_name_for_display (display,							"_NET_WM_STATE_SKIP_PAGER");      ++i;    }  if (i > 0)    {      XChangeProperty (xdisplay,                       xwindow,		       gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_STATE"),                       XA_ATOM, 32, PropModeReplace,                       (guchar*) atoms, i);    }  else     {      XDeleteProperty (xdisplay,                       xwindow,		       gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_STATE"));    }  if (private->state & GDK_WINDOW_STATE_STICKY)    {      atoms[0] = 0xFFFFFFFF;      XChangeProperty (xdisplay,                       xwindow,		       gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_DESKTOP"),                       XA_CARDINAL, 32, PropModeReplace,                       (guchar*) atoms, 1);    }  else    {      XDeleteProperty (xdisplay,                       xwindow,		       gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_DESKTOP"));    }  toplevel->map_serial = NextRequest (xdisplay);}static voidshow_window_internal (GdkWindow *window,                      gboolean   raise){  GdkWindowObject *private;  GdkDisplay *display;  GdkDisplayX11 *display_x11;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美在线观看一区| 欧美性感一类影片在线播放| 日本不卡123| 亚洲午夜电影在线| 亚洲国产精品欧美一二99| 伊人色综合久久天天| 亚洲综合图片区| 亚洲午夜久久久久久久久电影网| 亚洲午夜激情av| 免费的成人av| 丰满放荡岳乱妇91ww| 成人网男人的天堂| 91麻豆高清视频| 欧美日韩三级在线| 日韩欧美一级在线播放| 欧美精品一区在线观看| 亚洲国产高清在线| 一卡二卡三卡日韩欧美| 婷婷中文字幕一区三区| 久久99日本精品| 日韩一区二区免费视频| 欧美日韩一区久久| 亚洲精品一线二线三线| 亚洲国产精品高清| 婷婷中文字幕综合| 丁香一区二区三区| 欧美日韩一区二区不卡| 精品国产一区二区三区忘忧草| 久久久99精品久久| 亚洲一区二区欧美| 国产精品综合网| 色88888久久久久久影院野外 | 欧美国产禁国产网站cc| 亚洲天堂精品在线观看| 午夜视频一区在线观看| 国产九色sp调教91| 91精品91久久久中77777| 欧美不卡在线视频| 国产精品电影一区二区| 久久爱www久久做| 欧美日韩精品一区二区天天拍小说| 精品国产自在久精品国产| 亚洲激情校园春色| 国产91露脸合集magnet| 欧美精品 日韩| 日韩理论片网站| 国产一区二区三区精品视频| 色爱区综合激月婷婷| 久久精品夜色噜噜亚洲aⅴ| 亚洲成a人片综合在线| 成人美女在线视频| 欧美成人性福生活免费看| 亚洲欧美日韩在线| 懂色av一区二区夜夜嗨| 日韩一区二区三| 午夜a成v人精品| 欧美综合天天夜夜久久| 亚洲三级在线播放| 夫妻av一区二区| 国产日韩欧美不卡| 久久99久久99精品免视看婷婷 | 欧美激情一区在线观看| 激情综合网天天干| 日韩一级二级三级| 天天av天天翘天天综合网 | 欧美成人精品福利| 天堂精品中文字幕在线| 欧美日韩一区三区| 亚洲综合色视频| 色8久久人人97超碰香蕉987| 国产精品大尺度| 99久久精品免费| 亚洲色图丝袜美腿| 91色视频在线| 亚洲综合激情另类小说区| 91免费视频观看| 伊人色综合久久天天人手人婷| 91麻豆国产香蕉久久精品| 亚洲欧美日韩国产手机在线 | 麻豆精品视频在线观看视频| 91精品国产91综合久久蜜臀| 三级在线观看一区二区| 日韩欧美国产午夜精品| 国内精品伊人久久久久av影院| 久久久久亚洲蜜桃| 成人免费观看av| 国产精品国产三级国产普通话99| av毛片久久久久**hd| 亚洲综合激情另类小说区| 欧美美女视频在线观看| 丝袜国产日韩另类美女| 久久亚洲精品国产精品紫薇| 国产精品一区二区三区乱码| 欧美高清一级片在线观看| 99re8在线精品视频免费播放| 亚洲精品免费在线| 日韩一级片在线观看| 国产一区二区三区免费观看| 国产精品麻豆久久久| 精品1区2区3区| 久久99精品国产麻豆不卡| 国产三级欧美三级| 9色porny自拍视频一区二区| 婷婷六月综合网| 国产日韩精品久久久| 99久久精品国产一区| 秋霞影院一区二区| 亚洲国产精品成人综合色在线婷婷| 一本色道a无线码一区v| 久久精品国产免费| 亚洲乱码国产乱码精品精小说| 欧美精品自拍偷拍动漫精品| 成人av电影观看| 日韩中文字幕区一区有砖一区 | 欧美日韩国产精品自在自线| 国内精品伊人久久久久av影院| 亚洲久本草在线中文字幕| 精品捆绑美女sm三区| 色一情一伦一子一伦一区| 麻豆精品在线观看| 亚洲国产另类av| 国产精品女同互慰在线看| 欧美一二三在线| 色av成人天堂桃色av| 成人午夜av影视| 国产精品一区二区三区乱码| 午夜av电影一区| 亚洲欧美日韩国产一区二区三区| 久久久影视传媒| 欧美一级久久久久久久大片| 色综合久久中文字幕| 国产成人福利片| 精品一区二区三区在线播放| 性感美女极品91精品| 亚洲欧美一区二区不卡| 国产精品伦一区二区三级视频| 日韩免费观看高清完整版| 欧美精品亚洲一区二区在线播放| 色综合一个色综合| 不卡视频在线看| 成人激情图片网| 国产精品69久久久久水密桃| 激情国产一区二区| 裸体一区二区三区| 青娱乐精品在线视频| 日韩精品一二三区| 日本vs亚洲vs韩国一区三区二区 | 欧美一区二区三区思思人| 一本一道久久a久久精品| 91丨九色丨黑人外教| av一区二区三区| 99久久精品一区| 色一情一乱一乱一91av| 在线国产亚洲欧美| 欧美日韩视频专区在线播放| 欧洲亚洲国产日韩| 欧美猛男超大videosgay| 91麻豆精品久久久久蜜臀| 欧美日韩dvd在线观看| 69堂成人精品免费视频| 日韩欧美卡一卡二| 久久人人97超碰com| 国产精品日韩精品欧美在线| 国产精品久久久久三级| 亚洲另类在线视频| 亚洲第一成年网| 美女免费视频一区| 国产经典欧美精品| 97精品超碰一区二区三区| 欧美手机在线视频| 久久综合九色综合97婷婷| 欧美国产禁国产网站cc| 又紧又大又爽精品一区二区| 亚洲成人综合视频| 国产一区二区免费视频| 99久久精品免费看国产| 欧美二区三区的天堂| 久久精品视频在线看| 亚洲柠檬福利资源导航| 免费观看久久久4p| av成人老司机| 日韩一区二区三区四区| 国产精品美女久久久久久久久| 亚洲制服丝袜在线| 韩国女主播一区| 日本精品一区二区三区四区的功能| 在线综合视频播放| 亚洲女同女同女同女同女同69| 五月天一区二区三区| 国产成a人亚洲| 欧美日韩电影在线| 综合激情成人伊人| 国产精品一区在线观看你懂的| 一本大道久久精品懂色aⅴ| 欧美不卡一区二区三区| 一区二区高清视频在线观看| 国产精品一线二线三线| 91麻豆精品国产无毒不卡在线观看| 国产日产欧产精品推荐色| 日本特黄久久久高潮|