找回密码
 立即注册
查看: 3640|回复: 0

Tizen应用程序中创建窗格

[复制链接]
发表于 2015-10-26 15:17:19 | 显示全部楼层 |阅读模式
这篇教程解释了怎样使用应用程序中的窗格。

此功能只支持移动应用程序。

初始化面板应用程序
创建一个窗口标题 表格教程 ,由一个符合性组件包含naviframe组件。

复制代码

创建面板组件
一个新的窗格对象添加到应用程序中,在做这件事 _create () 函数。

当你创建一个窗格组件, elm_panes 2内容组件添加一个可拖动的目的。 拖时,这条尺寸内容的大小。 创建一个新的面板组件到一个基本对象,使用 elm_panes_add () 函数。

在以下示例中,窗格naviframe组件创建并添加:


  1. // Add an elm_panes
  2. panes = elm_panes_add(naviframe);
  3. evas_object_size_hint_weight_set(panes, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
  4. elm_win_resize_object_add(win, panes);
  5. evas_object_show(panes);

  6. nav_it = elm_naviframe_item_push(naviframe, "Panes view", NULL, NULL, panes, NULL);
复制代码

配置窗格配置面板组件:

修改定位与玻璃组件 elm_panes_horizontal_set () 函数。

默认情况下,面板组件的方向是垂直的。

  1. // Add a horizontal elm_panes
  2. panes_h = elm_panes_add(naviframe);
  3. elm_panes_horizontal_set(panes_h, EINA_TRUE);
复制代码

上面的代码创建一个窗格对象并设置水平方向。 在窗格添加内容,使用 elm_object_part_content_set () 函数。 在下面的例子中,水平面板组件( panes_h )添加到 “左” 窗格的一部分组件( 窗格 在上一步中创建用例。

  1. elm_object_part_content_set(panes, "left", panes_h);
复制代码

设置对象的一个按钮 “正确” 一边的垂直透明组件:
  1. // Create a button object
  2. bt = elm_button_add(naviframe);
  3. elm_object_text_set(bt, "Right");
  4. evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
  5. evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
  6. evas_object_show(bt);

  7. // Set the button object to the "right" part of the vertical panes
  8. elm_object_part_content_set(panes, "right", bt);
复制代码

水平的内容窗格设置组件2按钮对象(向上和向下)。

当填充一个垂直窗格显示组件,左边内容放置在顶部和底部放置正确的内容。


  1. // Create an "Up" button
  2. bt = elm_button_add(naviframe);
  3. elm_object_text_set(bt, "Up");
  4. evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
  5. evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
  6. evas_object_show(bt);
  7. elm_object_part_content_set(panes_h, "left", bt);

  8. // Create a "Down" button
  9. bt = elm_button_add(naviframe);
  10. elm_object_text_set(bt, "Down");
  11. evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
  12. evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
  13. evas_object_show(bt);
  14. elm_object_part_content_set(panes_h, "right", bt);
复制代码

调整透明组件。

改变玻璃组件的大小,拖动 elm_panes 用鼠标。 比例还可以设置的 elm_panes_content_left_size_set () 和 elm_panes_content_right_size_set () 功能。 下面的例子显示了如何设置了大小两个窗格的80%。

  1. // Set the proportion of the panes to 80%
  2. elm_panes_content_left_size_set(panes, 0.8);
  3. elm_panes_content_left_size_set(panes_h, 0.8);
复制代码


设置一个固定大小的玻璃组件的大小和比例 elm_panes_fixed_set () 函数。

  1. // Fix the panes proportion
  2. elm_panes_fixed_set(panes_h, EINA_TRUE);
复制代码

图:窗格教程




处理信号
面板组件发出4种不同的信号,根据用户交互可拖动的酒吧:

点击 ——点击面板。
下面的例子,一个回调函数注册到垂直面板组件,并打印 点击 到标准输出:


  1. // clicked callback
  2. static void
  3. _clicked_cb(void *data, Evas_Object *obj, void *event_info)
  4. {
  5.    dlog_print(DLOG_INFO, PANES_TAG, "Clicked\n");
  6. }

  7. evas_object_smart_callback_add(panes, "clicked", _clicked_cb, panes);
复制代码

新窗格。
下面的例子,一个回调函数注册到垂直面板组件,并打印 按下 到标准输出:


  1. // press callback
  2. static void
  3. _press_cb(void *data, Evas_Object *obj, void *event_info)
  4. {
  5.    dlog_print(DLOG_INFO, PANES_TAG, "Pressed\n");
  6. }

  7. evas_object_smart_callback_add(panes, "press", _press_cb, panes);
复制代码

unpressed ——窗格被按下后被发布。
下面的例子,一个回调函数注册到垂直面板组件,它输出的比例大小左窗格的内容组件使用的标准输出 elm_panes_content_left_size_get () 功能:


  1. // unpress callback
  2. static void
  3. _unpress_cb(void *data, Evas_Object *obj, void *event_info)
  4. {
  5.    dlog_print(DLOG_INFO, PANES_TAG, "Unpressed, size : %f\n",
  6.               elm_panes_content_left_size_get(obj));
  7. }

  8. evas_object_smart_callback_add(panes, "unpress", _unpress_cb, panes);
复制代码

点击 , 窗格中双击运行。
下面的例子,一个回调函数注册到垂直面板组件。 它藏起了太阳,而左窗格组件的一部分并设置左比例为0.0。 恢复了一部分比例,双击隐藏面板组件的一部分,使用 elm_panes_content_left_size_get () 和 elm_panes_content_left_size_set () 函数和一个变量来存储当前的价值比例。

  1. // clicked,double callback
  2. static void
  3. _clicked_double_cb(void *data, Evas_Object *obj, void *event_info)
  4. {
  5.    static double size = 0.0;
  6.    double tmp_size = 0.0;
  7.    tmp_size = elm_panes_content_left_size_get(obj);
  8.    if (tmp_size > 0)
  9.    {
  10.       elm_panes_content_left_size_set(obj, 0.0);
  11.       dlog_print(DLOG_INFO, PANES_TAG, "Double clicked, hidden.\n");
  12.    }
  13.    else
  14.    {
  15.       elm_panes_content_left_size_set(obj, size);
  16.       dlog_print(DLOG_INFO, PANES_TAG,
  17.                  "Double clicked, restoring size.\n");
  18.    }
  19.    size = tmp_size;
  20. }

  21. evas_object_smart_callback_add(panes, "clicked,double", _clicked_double_cb, panes);
复制代码

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
欢迎来到泰泽网:http://www.tizennet.com/ 泰泽论坛:http://bbs.tizennet.com/ 好没有内涵哦,快到设置中更改这个无聊的签名吧!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|泰泽应用|泰泽论坛|泰泽网|小黑屋|Archiver|手机版|泰泽邮箱|泰泽网 ( 蜀ICP备13024062号-1 )

GMT+8, 2024-11-24 03:10 , Processed in 0.044799 second(s), 20 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表