awtk/docs/self_layouter_menu.md
2020-08-16 09:10:01 +08:00

121 lines
3.0 KiB
Markdown
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# menu 自身布局器 (self\_layouter\_menu) 介绍
## 1. 概述
用于确定菜单的位置和大小,菜单一般用 popup 窗口或 dialog 来实现。
缺省布局中有 5 个参数:
* x x 参数
* y y 参数
* w 宽度
* h 高度
* position 位置
## 2. 位置确定
### 2.1 缺省位置
由当前点击的位置决定菜单弹出的位置。菜单弹出的位置在当前点击位置的右下角(会根据屏幕大小适当调整,以确保菜单在屏幕范围内)
```
<popup self_layout="menu(w=128,h=90)" close_when_click_outside="true">
...
</popup>
```
![awtk_menu_point.jpg](images/awtk_menu_point.jpg)
> 可以通过 w/h 指定菜单的宽度和高度,支持百分比方式。
### 2.2 在触发的控件的上方 (position=up) 或下方 (position=down)。
比如点击一个按钮时弹出菜单position=up 让菜单在按钮的上方弹出position=down 让菜单在按钮的下方弹出。
可以通过 x 参数指定菜单与触发控件的对齐关系。
* 缺省左对齐。
* center 中心对齐。
* right 右对齐。
可以通过 w/h 指定菜单的宽度和高度,支持百分比方式。
可以通过 y 指定菜单与触发控件之间的间距。
示例:
下方左对齐:
```
<popup style="dark" self_layout="menu(position=down,x=left,w=128,h=90)" close_when_click="true">
...
</popup>
```
![awtk_menu_down_left.jpg](images/awtk_menu_down_left.jpg)
下方中心对齐:
```xml
<popup style="dark" self_layout="menu(position=down,x=center,w=128,h=90)" close_when_click="true">
</popup>
```
![awtk_menu_down_center.jpg](images/awtk_menu_down_center.jpg)
下方右对齐:
```
<popup style="dark" self_layout="menu(position=down,x=right,w=128,h=90)" close_when_click="true">
</popup>
```
![awtk_menu_down_right.jpg](images/awtk_menu_down_right.jpg)
### 2.3 在触发的控件的右边 (position=right) 或左边 (position=left)。
比如点击一个按钮时弹出菜单position=right 让菜单在按钮的右边弹出position=left 让菜单在按钮的左边弹出。
可以通过 y 参数指定菜单与触发控件的对齐关系。
* 缺省顶部对齐。
* middle 中心对齐。
* bottom 底部对齐。
可以通过 w/h 指定菜单的宽度和高度,支持百分比边式。
可以通过 x 指定菜单与触发控件之间的间距。
示例:
左边顶部对齐:
```
<popup style="dark" self_layout="menu(position=left,y=top,w=128,h=90)" close_when_click="true">
...
</popright>
```
![awtk_menu_left_top.jpg](images/awtk_menu_left_top.jpg)
左边中心对齐:
```xml
<popup style="dark" self_layout="menu(position=left,y=middle,w=128,h=90)" close_when_click="true">
</popright>
```
![awtk_menu_left_middle.jpg](images/awtk_menu_left_middle.jpg)
左边底部对齐:
```
<popup style="dark" self_layout="menu(position=left,y=bottom,w=128,h=90)" close_when_click="true">
</popright>
```
![awtk_menu_left_bottom.jpg](images/awtk_menu_left_bottom.jpg)
更多例子请参考[menu.xml](https://github.com/zlgopen/awtk/blob/master/demos/assets/raw/ui/menu.xml)。