进度条 Progress Bars@GTK+ 2.0 中文教程连载(原文编译时73行有误:default:后应加 ;号做空语句)

进度条 Progress Bars

进度条用于显示正在进行的操作的状态。在下面的代码中可以看出,它相当容易使用。下面的内容从创建一个新进度条开始。

GtkWidget *gtk_progress_bar_new( void );

创建进度条后就可以使用它了。

void gtk_progress_bar_set_fraction ( GtkProgressBar *pbar,

gdouble fraction );

第一个参数是希望操作的进度条,第二个参数是“已完成”的百分比,意思是进度条从0-100%已经填充的数量。它以0~1范围的实数传递给函数。

GTK 1.2版已经给进度条添加了一个新的功能,那就是允许它以不同的方法显示其值,并通知用户它的当前值和范围。

进度条可以用以下函数设置它的移动方向:

void gtk_progress_bar_set_orientation( GtkProgressBar *pbar,

GtkProgressBarOrientation orientation );

orientation 参数可以取下列值之一,以指示进度条的移动方向:

  GTK_PROGRESS_LEFT_TO_RIGHT  从左向右

GTK_PROGRESS_RIGHT_TO_LEFT 从右向左

GTK_PROGRESS_BOTTOM_TO_TOP 从下向上

GTK_PROGRESS_TOP_TO_BOTTOM 从上向下

除了指示进度已经发生的数量以外,进度条还可以设置为仅仅指示有活动在继续,即活动状态。这在进度无法按数值度量的情况下很有用。用下面的函数来表明进度有了些进展。

void gtk_progress_bar_pulse ( GtkProgressBar *progress );

活动指示的步数由以下函数设置:

void gtk_progress_bar_set_pulse_step( GtkProgressBar *pbar,

gdouble fraction );

在非活动状态下,进度条可以用下列函数在滑槽里显示一个可配置的文本串:

void gtk_progress_bar_set_text( GtkProgressBar *progress,

const gchar *text );
Note

注意,gtk_progress_set_text()不再支持 GTK+ 1.2版进度条里那种类似printf()的格式参数

你可以通过调用 gtk_progess_bar_set_text() 并把 NULL 作为第二个参数来关闭文本串的显示.

进度条的当前文本设置能由下面的函数取得。不要释放返回的字符串.

const gchar *gtk_progress_bar_get_text( GtkProgressBar *pbar );

进度条通常和timeouts或其它类似函数同时使用(详见 超时、I/O 和 Idle 函数 这一章),使应用程序就像是多任务一样。一般都以同样的方式调用 gtk_progress_bar_set_fraction() 或 gtk_progress_bar_pulse() 函数。

下面是一个进度条的示例,用timeout函数更新进度条的值。代码也演示了怎样复位进度条。

#include <gtk/gtk.h>



typedef struct _ProgressData {

GtkWidget *window;

GtkWidget *pbar;

int timer;

gboolean activity_mode;

} ProgressData;



/* 更新进度条,这样就能够看到进度条的移动 */

gint progress_timeout( gpointer data )

{

ProgressData *pdata = (ProgressData *)data;

gdouble new_val;



if (pdata->activity_mode)

gtk_progress_bar_pulse (GTK_PROGRESS_BAR (pdata->pbar));

else

{

/* 使用在调整对象中设置的取值范围计算进度条的值 */



new_val = gtk_progress_bar_get_fraction (GTK_PROGRESS_BAR (pdata->pbar)) + 0.01;



if (new_val > 1.0)

new_val = 0.0;



/* 设置进度条的新值 */

gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR (pdata->pbar), new_val);

}



/* 这是一个timeout函数,返回 TRUE,这样它就能够继续被调用 */

return TRUE;

}



/* 回调函数,切换在进度条你的滑槽上的文本显示 */

void toggle_show_text( GtkWidget *widget,

ProgressData *pdata )

{

const gchar *text;



text = gtk_progress_bar_get_text (GTK_PROGRESS_BAR (pdata->pbar));

if (text && *text)

gtk_progress_bar_set_text (GTK_PROGRESS_BAR (pdata->pbar), "");

else

gtk_progress_bar_set_text (GTK_PROGRESS_BAR (pdata->pbar), "some text");

}



/* 回调函数,切换进度条的活动模式 */

void toggle_activity_mode( GtkWidget *widget,

ProgressData *pdata )

{

pdata->activity_mode = !pdata->activity_mode;

if (pdata->activity_mode)

gtk_progress_bar_pulse (GTK_PROGRESS_BAR (pdata->pbar));

else

gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR (pdata->pbar), 0.0);

}





/* 回调函数,切换进度条的移动方向 */

void toggle_orientation( GtkWidget *widget,

ProgressData *pdata )

{

switch (gtk_progress_bar_get_orientation (GTK_PROGRESS_BAR (pdata->pbar))) {

case GTK_PROGRESS_LEFT_TO_RIGHT:

gtk_progress_bar_set_orientation (GTK_PROGRESS_BAR (pdata->pbar),

GTK_PROGRESS_RIGHT_TO_LEFT);

break;

case GTK_PROGRESS_RIGHT_TO_LEFT:

gtk_progress_bar_set_orientation (GTK_PROGRESS_BAR (pdata->pbar),

GTK_PROGRESS_LEFT_TO_RIGHT);

break;

default:

// 什么也不做

}

}





/* 清除分配的内存,删除定时器(timer) */

void destroy_progress( GtkWidget *widget,

ProgressData *pdata)

{

gtk_timeout_remove (pdata->timer);

pdata->timer = 0;

pdata->window = NULL;

g_free (pdata);

gtk_main_quit ();

}



int main( int argc,

char *argv[])

{

ProgressData *pdata;

GtkWidget *align;

GtkWidget *separator;

GtkWidget *table;

GtkWidget *button;

GtkWidget *check;

GtkWidget *vbox;



gtk_init (&argc, &argv);



/* 为传递到回调函数中的数据分配内存 */

pdata = g_malloc (sizeof (ProgressData));



pdata->window = gtk_window_new (GTK_WINDOW_TOPLEVEL);

gtk_window_set_resizable (GTK_WINDOW (pdata->window), TRUE);



g_signal_connect (G_OBJECT (pdata->window), "destroy",

G_CALLBACK (destroy_progress),

pdata);

gtk_window_set_title (GTK_WINDOW (pdata->window), "GtkProgressBar");

gtk_container_set_border_width (GTK_CONTAINER (pdata->window), 0);



vbox = gtk_vbox_new (FALSE, 5);

gtk_container_set_border_width (GTK_CONTAINER (vbox), 10);

gtk_container_add (GTK_CONTAINER (pdata->window), vbox);

gtk_widget_show (vbox);



/* 创建一个居中对齐的对象 */

align = gtk_alignment_new (0.5, 0.5, 0, 0);

gtk_box_pack_start (GTK_BOX (vbox), align, FALSE, FALSE, 5);

gtk_widget_show (align);



/* 创建进度条 */

pdata->pbar = gtk_progress_bar_new ();



gtk_container_add (GTK_CONTAINER (align), pdata->pbar);

gtk_widget_show (pdata->pbar);



/* 加一个定时器(timer),以更新进度条的值 */

pdata->timer = gtk_timeout_add (100, progress_timeout, pdata);



separator = gtk_hseparator_new ();

gtk_box_pack_start (GTK_BOX (vbox), separator, FALSE, FALSE, 0);

gtk_widget_show (separator);



/* 行数、列数、同质性(homogeneous) */

table = gtk_table_new (2, 2, FALSE);

gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, TRUE, 0);

gtk_widget_show (table);



/* 添加一个复选按钮,以选择是否显示在滑槽里的文本 */

check = gtk_check_button_new_with_label ("Show text");

gtk_table_attach (GTK_TABLE (table), check, 0, 1, 0, 1,

GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,

5, 5);

g_signal_connect (G_OBJECT (check), "clicked",

G_CALLBACK (toggle_show_text),

pdata);

gtk_widget_show (check);



/* 添加一个复选按钮,切换活动状态 */

check = gtk_check_button_new_with_label ("Activity mode");

gtk_table_attach (GTK_TABLE (table), check, 0, 1, 1, 2,

GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,

5, 5);

g_signal_connect (G_OBJECT (check), "clicked",

G_CALLBACK (toggle_activity_mode),

pdata);

gtk_widget_show (check);



/* 添加一个复选按钮,切换移动方向 */

check = gtk_check_button_new_with_label ("Right to Left");

gtk_table_attach (GTK_TABLE (table), check, 0, 1, 2, 3,

GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,

5, 5);

g_signal_connect (G_OBJECT (check), "clicked",

G_CALLBACK (toggle_orientation),

pdata);

gtk_widget_show (check);



/* 添加一个按钮,用来退出应用程序 */

button = gtk_button_new_with_label ("close");

g_signal_connect_swapped (G_OBJECT (button), "clicked",

G_CALLBACK (gtk_widget_destroy),

pdata->window);

gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);



/* 将按钮设置为能缺省的构件 */

GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);



/* 将缺省焦点设置到这个按钮上,使之成为缺省按钮,只要按回车键

* 就相当于点击了这个按钮 */

//译者注: 能缺省的构件在获取焦点后成为缺省构件,用户按方向键等可以切换焦点。

gtk_widget_grab_default (button);

gtk_widget_show (button);



gtk_widget_show (pdata->window);



gtk_main ();



return 0;

}

<<< Previous Home Next >>>
工具提示对象 The Tooltips ObjectUp 对话框 Dialogs
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
图像识别技术在病虫害检测中的应用是一个快速发展的领域,它结合了计算机视觉和机器学习算法来自动识别和分类植物上的病虫害。以下是这一技术的一些关键步骤和组成部分: 1. **数据收集**:首先需要收集大量的植物图像数据,这些数据包括健康植物的图像以及受不同病虫害影响的植物图像。 2. **图像预处理**:对收集到的图像进处理,以提高后续分析的准确性。这可能包括调整亮度、对比度、去噪、裁剪、缩放等。 3. **特征提取**:从图像中提取有助于识别病虫害的特征。这些特征可能包括颜色、纹理、形状、边缘等。 4. **模型训练**:使用机器学习算法(如支持向量机、随机森林、卷积神经网络等)来训练模型。训练过程中,算法会学习如何根据提取的特征来识别不同的病虫害。 5. **模型验证和测试**:在独立的测试集上验证模型的性能,以确保其准确性和泛化能力。 6. **部署和应用**:将训练好的模型部署到实际的病虫害检测系统中,可以是移动应用、网页服务或集成到智能农业设备中。 7. **实监测**:在实际应用中,系统可以实接收植物图像,并快速给出病虫害的检测结果。 8. **持续学习**:随着间的推移,系统可以不断学习新的病虫害样本,以提高其识别能力。 9. **用户界面**:为了方便用户使用,通常会有一个用户友好的界面,显示检测结果,并提供进一步的指导或建议。 这项技术的优势在于它可以快速、准确地识别出病虫害,甚至在早期阶段就能发现问题,从而及采取措施。此外,它还可以减少对化学农药的依赖,支持可持续农业发展。随着技术的不断进步,图像识别在病虫害检测中的应用将越来越广泛。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值