⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 x427.html

📁 介绍GTK+2.0不错的资料~上面从最基本的方面说到gtk程序编写~适合初学者
💻 HTML
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"><HTML><HEAD><TITLE>盒的细节</TITLE><METANAME="GENERATOR"CONTENT="Modular DocBook HTML Stylesheet Version 1.76b+"><LINKREL="HOME"TITLE="GTK+ 2.0 教程"HREF="book1.html"><LINKREL="UP"TITLE="组装构件"HREF="c418.html"><LINKREL="PREVIOUS"TITLE="组装构件"HREF="c418.html"><LINKREL="NEXT"TITLE="组装示范程序"HREF="x450.html"></HEAD><BODYCLASS="SECT1"BGCOLOR="#FFFFFF"TEXT="#000000"LINK="#0000FF"VLINK="#840084"ALINK="#0000FF"><DIVCLASS="NAVHEADER"><TABLESUMMARY="Header navigation table"WIDTH="100%"BORDER="0"CELLPADDING="0"CELLSPACING="0"><TR><THCOLSPAN="3"ALIGN="center">GTK+ 2.0 教程</TH></TR><TR><TDWIDTH="10%"ALIGN="left"VALIGN="bottom"><AHREF="c418.html"ACCESSKEY="P">&#60;&#60;&#60; Previous</A></TD><TDWIDTH="80%"ALIGN="center"VALIGN="bottom">组装构件</TD><TDWIDTH="10%"ALIGN="right"VALIGN="bottom"><AHREF="x450.html"ACCESSKEY="N">Next &#62;&#62;&#62;</A></TD></TR></TABLE><HRALIGN="LEFT"WIDTH="100%"></DIV><DIVCLASS="SECT1"><H1CLASS="SECT1"><ANAME="SEC-DETAILSOFBOXES">盒的细节</H1><P>由于存在这样的弹性,所以在一开始使用 GTK 中的组装盒(packing box)的时候会有点让人迷惑。这里有许多选项,并且它们不容易一眼看出是如何组合在一起的。然而到最后,这里基本上只有五种不同的风格。</P><P><SPANCLASS="INLINEMEDIAOBJECT"><IMGSRC="images/packbox1.png"></SPAN></P><P>每一行包含一个带有若干按钮的横向盒。gtk_box_pack 是组装每个按钮到横向盒(hbox)的简写。每个按钮都是以同样的方式组装到横向盒里的(例如,以同样参数调用 gtk_box_pack_start() 函数)。</P><P>这是 gtk_box_pack_start() 函数的声明。</P><TABLEBORDER="0"BGCOLOR="#E0E0E0"WIDTH="100%"><TR><TD><PRECLASS="PROGRAMLISTING">void gtk_box_pack_start( GtkBox    *box,                         GtkWidget *child,                         gboolean   expand,                         gboolean   fill,                         guint      padding );</PRE></TD></TR></TABLE><P>第一个参数是你要把对象组装进去的盒,第二个就是该对象。目前这些对象将都是按钮,即我们要将这些按钮组装到盒中。</P><P>gtk_box_pack_start() 和 gtk_box_pack_end() 中的 expand 参数是用来控制构件在盒中是充满所有多余空间这样盒会扩展到充满所有分配给它的空间(TURE);还是盒收缩到仅仅符合构件的大小(FALSE)。设置 expand 为 FALSE 将允许你向左或向右对齐你的构件。否则,它们会在盒中展开,同样的效果只要用 gkt_box_pack_start() 或 gtk_box_pack_end() 之一就能实现。</P><P>fill 参数在 gtk_box_pack 中控制多余空间是分配给对象本身(TRUE),还是让多余空间围绕在这些对象周围分布(FALSE)。它只有在 expand 参数也为 TRUE 时才会生效。</P><P>当创建一个新盒时,函数看起来像下面这样:</P><TABLEBORDER="0"BGCOLOR="#E0E0E0"WIDTH="100%"><TR><TD><PRECLASS="PROGRAMLISTING">GtkWidget *gtk_hbox_new ( gboolean homogeneous,                          gint     spacing );</PRE></TD></TR></TABLE><P>gtk_hbox_new() 的 homogeneous 参数(对于gtk_vbox_new()也是一样)控制是否盒里的每个对象具有相同的大小(例如,在横向盒中等宽,或在纵向盒中等高)。若它被设置,gtk_box_pack()常规函数的<TTCLASS="LITERAL">expand</TT>参数就被忽略了,它本质上总被开启。</P><P>spacing(当盒被创建时设置)和 padding(当元素被组装时设置)有什么区别呢?Spacing 是加在对象之间,而 papadding 加在对象的每一边。看下面这张图应该会明白一点:</P><P><SPANCLASS="INLINEMEDIAOBJECT"><IMGSRC="images/packbox2.png"></SPAN></P><P>这面是产生上面这些图片的代码,其中做了不少注释,所以我希望你看下去不会有任何问题。自己编译它并玩玩它吧。</P></DIV><DIVCLASS="NAVFOOTER"><HRALIGN="LEFT"WIDTH="100%"><TABLESUMMARY="Footer navigation table"WIDTH="100%"BORDER="0"CELLPADDING="0"CELLSPACING="0"><TR><TDWIDTH="33%"ALIGN="left"VALIGN="top"><AHREF="c418.html"ACCESSKEY="P">&#60;&#60;&#60; Previous</A></TD><TDWIDTH="34%"ALIGN="center"VALIGN="top"><AHREF="book1.html"ACCESSKEY="H">Home</A></TD><TDWIDTH="33%"ALIGN="right"VALIGN="top"><AHREF="x450.html"ACCESSKEY="N">Next &#62;&#62;&#62;</A></TD></TR><TR><TDWIDTH="33%"ALIGN="left"VALIGN="top">组装构件</TD><TDWIDTH="34%"ALIGN="center"VALIGN="top"><AHREF="c418.html"ACCESSKEY="U">Up</A></TD><TDWIDTH="33%"ALIGN="right"VALIGN="top">组装示范程序</TD></TR></TABLE></DIV></BODY></HTML>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -