Android开发第二次课 布局方式

简介: Android开发第二次课 布局方式

线性布局

线性布局:

  • 控件从左到右排列:水平方式
  • 控件从上到下排列:垂直方式
    标签:LinearLayout
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
</LinearLayout>

xmlns:android:声明一个命名空间前缀,叫作android,http://schemas.android.com/apk/res/android,

是网址格式,才可以使用android前缀。

orientation="vertical" 是垂直排列

总体代码实现:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">
    <!--    线性布局;Ctrl+Alt+L键:格式化代码;-->
    <!--
        1.行 用户名: 输入框
        2.行 密码:输入框
        3.登录 取消
    -->
    <!-- 1.第一行线性布局:水平方式
            match_parent 表示使空间填充布局单元内的尽可能多的空间,
            wrap_content:表示使视图扩展以现实全部内容;
            layout_width:布局宽;
            layout_height:height:布局高度;
            txt:文本内容
            textSize:文本大小
            layout_weight:字体粗细
            paddingLeft:左填充
            paddingTop:上填充;
       -->
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:paddingLeft="15dp"
            android:paddingTop="15dp"
            android:text="用户"
            android:textSize="20dp" />
        <EditText
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="3" />
    </LinearLayout>
    <!--    第二行,线性布局,水平方式-->
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:paddingLeft="10dp"
            android:paddingTop="10dp"
            android:text="密码"
            android:textSize="20dp" />
        <EditText
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="3" />
    </LinearLayout>
    <!--    第三行,线性布局,水平方式-->
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <Button
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="登录"/>
        <Button
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="取消"/>
    </LinearLayout>
</LinearLayout>

除了LinearLayout线性布局之外,里面,讲了三个控件;

1.TextView:显示文本提示信息;

2.EditText:输入框;

3.Button:按钮

2.表格布局

office:excel工具。

表格布局是按照行和列来组织子视图的布局,包含一系列的TableRow对象,用于定义行。

TableLayout–>TableRow

可以包含0个以上的单元格,每个单元格可以设置一个View视图。

stretchColumns="*":从0开始的索引项,可以拉伸,*号大题拉伸的所有列。
shrinkColumns="*":收缩从0开始的索引项。

下面是9个图标下载热门的案例

<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:shrinkColumns="*"
    android:stretchColumns="*">
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="热门下载"
        android:textColor="@color/aqua"
        android:textSize="20dp" />
    <!--    表格里面包含:TableRow-->
    <TableRow android:layout_weight="1">
        <!--        放置图片,ImageView;src:表示图标路径;scaleType:自动适应大小-->
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/iod"
            android:scaleType="fitXY"/>
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/afari"
            android:scaleType="fitXY"/>
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/iod"
            android:scaleType="fitXY"/>
    </TableRow>
    <TableRow android:layout_weight="1">
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/iiontacts"
            android:scaleType="fitXY"/>
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/phone"
            android:scaleType="fitXY"/>
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/twitter"
            android:scaleType="fitXY"/>
    </TableRow>
    <TableRow android:layout_weight="1">
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/stocks"
            android:scaleType="fitXY"/>
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/hjamera"
            android:scaleType="fitXY"/>
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:src="@mipmap/wwwwww"
            android:scaleType="fitXY"/>
    </TableRow>
</TableLayout>

颜色

<color name="colorPrimary">#3F51B5</color><!--首要颜色-->
   <color name="colorPrimaryDark">#303F9F</color><!--首要颜色暗色-->
   <color name="colorAccent">#FF4081</color><!--色彩强调-->
   <color name="black">#000000</color><!--黑色 -->
   <color name="white">#FFFFFF</color><!--白色-->
   <color name="snow">#fffafa</color><!--雪白色 -->
   <color name="floralwhite">#fffaf0</color><!--花白色 -->
   <color name="blanchedalmond">#ffebcd</color><!--杏白色 -->
   <color name="ghostwhite">#f8f8ff</color><!--幽灵白 -->
   <color name="whitesmoke">#f5f5f5</color><!--烟白色 -->
   <color name="antiquewhite">#faebd7</color><!--古董白 -->
   <color name="navajowhite">#ffdead</color><!--纳瓦白 -->
   <color name="grey">#808080</color><!--灰色 -->
   <color name="gainsboro">#dcdcdc</color><!--淡灰色 -->
   <color name="lightgrey">#d3d3d3</color><!--亮灰色 -->
   <color name="darkgrey">#a9a9a9</color><!--暗灰色 -->
   <color name="dimgrey">#696969</color><!--暗灰色 -->
   <color name="slategrey">#708090</color><!--灰石色 -->
   <color name="lightslategrey">#778899</color><!--亮蓝灰 -->
   <color name="darkslategrey">#2f4f4f</color><!--暗瓦灰色 -->
   <color name="silver">#c0c0c0</color><!--银色 -->
   <color name="red">#ff0000</color><!--红色 -->
   <color name="darkred">#8b0000</color><!--暗红色 -->
   <color name="crimson">#dc143c</color><!--暗深红色 -->
   <color name="darkmagenta">#8b008b</color><!--暗洋红 -->
   <color name="fuchsia">#ff00ff</color><!--紫红色 -->
   <color name="tomato">#ff6347</color><!--西红柿色 -->
   <color name="lightcoral">#f08080</color><!--亮珊瑚色 -->
   <color name="darksalmon">#e9967a</color><!--暗肉色 -->
   <color name="peachpuff">#ffdab9</color><!--桃色 -->
   <color name="plum">#dda0dd</color><!--洋李色 -->
   <color name="pink">#ffc0cb</color><!--粉红色 -->
   <color name="lightpink">#ffb6c1</color><!--亮粉红色 -->
   <color name="deeppink">#ff1493</color><!--深粉红色 -->
   <color name="hotpink">#ff69b4</color><!--热粉红色 -->
   <color name="lavenderblush">#fff0f5</color><!--淡紫红 -->
   <color name="indianred">#cd5c5c</color><!--印第安红 -->
   <color name="rosybrown">#bc8f8f</color><!--褐玫瑰红 -->
   <color name="firebrick">#b22222</color><!--红砖色 -->
   <color name="maroon">#800000</color><!--粟色 -->
   <color name="honeydew">#f0fff0</color><!--蜜色 -->
   <color name="orangered">#ff4500</color><!--红橙色 -->
   <color name="orange">#ffa500</color><!--橙色 -->
   <color name="limegreen">#32cd32</color><!--橙绿色 -->
   <color name="lime">#00ff00</color><!--酸橙色 -->
   <color name="yellow">#ffff00</color><!--黄色 -->
   <color name="wheat">#f5deb3</color><!--浅黄色 -->
   <color name="khaki">#f0e68c</color><!--黄褐色 -->
   <color name="burlywood">#deb887</color><!--实木色 -->
   <color name="bisque">#ffe4c4</color><!--桔黄色 -->
   <color name="lightyellow">#ffffe0</color><!--亮黄色 -->
   <color name="darkgoldenrod">#b8860b</color><!--暗金黄色 -->
   <color name="darkorange">#ff8c00</color><!--暗桔黄色 -->
   <color name="lightgoldenrodyellow">#fafad2</color><!--亮金黄色 -->
   <color name="lemonchiffon">#fffacd</color><!--柠檬绸色 -->
   <color name="cornsilk">#fff8dc</color><!--米绸色 -->
   <color name="seaShell">#fff5ee</color><!--海贝色 -->
   <color name="papayawhip">#ffefd5</color><!--番木色 -->
   <color name="mistyrose">#ffe4e1</color><!--浅玫瑰色 -->
   <color name="moccasin">#ffe4b5</color><!--鹿皮色 -->
   <color name="ivory">#fffff0</color><!--象牙色 -->
   <color name="gold">#ffd700</color><!--金色 -->
   <color name="goldenrod">#daa520</color><!--金麒麟色 -->
   <color name="lightsalmon">#ffa07a</color><!--亮肉色 -->
   <color name="coral">#ff7f50</color><!--珊瑚色 -->
   <color name="mintcream">#f5fffa</color><!--薄荷色 -->
   <color name="beige">#f5f5dc</color><!--米色 -->
   <color name="sandybrown">#f4a460</color><!--沙褐色 -->
   <color name="oldlace">#fdf5e6</color><!--老花色 -->
   <color name="linen">#faf0e6</color><!--亚麻色 -->
   <color name="salmon">#fa8072</color><!--鲜肉色 -->
   <color name="thistle">#d8bfd8</color><!--蓟色 -->
   <color name="tan">#d2b48c</color><!--茶色 -->
   <color name="chocolate">#d2691e</color><!--巧可力色 -->
   <color name="peru">#cd853f</color><!--秘鲁色 -->
   <color name="darkkhaki">#bdb76b</color><!--暗黄褐色 -->
   <color name="palegoldenrod">#eee8aa</color><!--苍麒麟色 -->
   <color name="brown">#a52a2a</color><!--褐色 -->
   <color name="saddlebrown">#8b4513</color><!--重褐色 -->
   <color name="sienna">#a0522d</color><!--赭色 -->
   <color name="olive">#808000</color><!--橄榄色 -->
   <color name="chartreuse">#7fff00</color><!--黄绿色 -->
   <color name="greenyellow">#adff2f</color><!--黄绿色 -->
   <color name="green">#008000</color><!--绿色 -->
   <color name="darkgreen">#006400</color><!--暗绿色 -->
   <color name="darkolivegreen">#556b2f</color><!--暗橄榄绿 -->
   <color name="olivedrab">#6b8e23</color><!--深绿褐色 -->
   <color name="lawngreen">#7cfc00</color><!--草绿色 -->
   <color name="forestgreen">#228b22</color><!--森林绿 -->
   <color name="aquamarine">#7fffd4</color><!--碧绿色 -->
   <color name="paleturquoise">#afeeee</color><!--苍宝石绿 -->
   <color name="palegreen">#98fb98</color><!--苍绿色 -->
   <color name="mediumturquoise">#48d1cc</color><!--中绿宝石 -->
   <color name="mediumaquamarine">#66cdaa</color><!--中绿色 -->
   <color name="aqua">#00ffff</color><!--浅绿色 -->
   <color name="springgreen">#00ff7f</color><!--春绿色 -->
   <color name="mediumspringgreen">#00fa9a</color><!--中春绿色 -->
   <color name="darkturquoise">#00ced1</color><!--暗宝石绿 -->
   <color name="seagreen">#2e8b57</color><!--海绿色 -->
   <color name="lightgreen">#90ee90</color><!--亮绿色 -->
   <color name="darkseagreen">#8fbc8f</color><!--暗海兰色 -->
   <color name="turquoise">#40e0d0</color><!--青绿色 -->
   <color name="cyan">#00ffff</color><!--青色 -->
   <color name="darkcyan">#008b8b</color><!--暗青色 -->
   <color name="lightcyan">#e0ffff</color><!--亮青色 -->
   <color name="teal">#008080</color><!--水鸭色 -->
   <color name="indigo">#4b0082</color><!--靛青色 -->
   <color name="blue">#0000ff</color><!--蓝色 -->
   <color name="darkblue">#00008b</color><!--暗蓝色 -->
   <color name="mediumblue">#0000cd</color><!--中兰色 -->
   <color name="midnightblue">#191970</color><!--中灰兰色 -->
   <color name="navy">#000080</color><!--海军色 -->
   <color name="royalblue">#4169e1</color><!--皇家蓝 -->
   <color name="azure">#f0ffff</color><!--天蓝色 -->
   <color name="skyblue">#87ceeb</color><!--天蓝色 -->
   <color name="deepskyblue">#00bfff</color><!--深天蓝色 -->
   <color name="lightskyblue">#87cefa</color><!--亮天蓝色 -->
   <color name="lightseagreen">#20b2aa</color><!--亮海蓝色 -->
   <color name="lightblue">#add8e6</color><!--亮蓝色 -->
   <color name="powderblue">#b0e0e6</color><!--粉蓝色 -->
   <color name="aliceblue">#f0f8ff</color><!--艾利斯兰 -->
   <color name="mediumslateblue">#7b68ee</color><!--中暗蓝色 -->
   <color name="slateblue">#6a5acd</color><!--石蓝色 -->
   <color name="darkslateblue">#483d8b</color><!--暗灰蓝色 -->
   <color name="mediumseagreen">#3cb371</color><!--中海蓝 -->
   <color name="steelblue">#4682b4</color><!--钢兰色 -->
   <color name="lightsteelblue">#b0c4de</color><!--亮钢兰色 -->
   <color name="cornflowerblue">#6495ed</color><!--菊兰色 -->
   <color name="dodgerblue">#1e90ff</color><!--闪兰色 -->
   <color name="cadetblue">#5f9ea0</color><!--军兰色 -->
   <color name="blueviolet">#8a2be2</color><!--紫罗兰蓝色 -->
   <color name="purple">#800080</color><!--紫色 -->
   <color name="lavender">#e6e6fa</color><!--淡紫色 -->
   <color name="orchid">#da70d6</color><!--淡紫色 -->
   <color name="mediumpurple">#9370db</color><!--中紫色 -->
   <color name="darkorchid">#9932cc</color><!--暗紫色 -->
   <color name="violet">#ee82ee</color><!--紫罗兰色 -->
   <color name="mediumvioletred">#c71585</color><!--中紫罗兰色 -->
   <color name="palevioletred">#db7093</color><!--苍紫罗兰色 -->
   <color name="darkviolet">#9400d3</color><!--暗紫罗兰色 -->
   <color name="mediumorchid">#ba55d3</color><!--中粉紫色 -->

3.相对布局

控件的位置是相对于其他控件或者父容器而言。在进行设计的时候,需要按照控件之间的依赖关系进行排列。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <!--    增加几个按钮;
        layout_centerInParent:如果为true,则表示该空间位于父控件的中央位置;
        layout_centerHorizontal:如果为true,则表示该空间位于负控件的居中位置;
        layout_centerVertical:如果为true,则表示该控件置于父空间的垂直居中位置;
        layout_above:将该控件位于给定控件的上方。
        layout_below:将该控件位于给定控件的下方。
        layout_toLeftOf:将该控件的右边缘与给定Id的控件左边缘对齐;
        layout_toRightOf:将该控件的左边缘与给定Id的控件右边缘对齐;
        -->
        <Button
            android:id="@+id/bt_center"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:text="中间" />
        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/bt_up"
            android:layout_above="@id/bt_center"
            android:layout_centerHorizontal="true"
            android:text="向上"/>
        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/bt_down"
            android:layout_below="@id/bt_center"
            android:layout_centerHorizontal="true"
            android:text="向下"/>
        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/bt_left"
            android:layout_toLeftOf="@id/bt_center"
            android:layout_centerVertical="true"
            android:text="居左"/>
        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/bt_Right"
            android:layout_toRightOf="@id/bt_center"
            android:layout_centerVertical="true"
            android:text="居右"/>
    </RelativeLayout>

4.帧布局

帧布局是布局中最简单的一个布局,整个界面被当做一块空白备用区域,所有的子元素都不能指定位置进行放置,全部放置于这块儿区域的左上角,并且后面的子元素直接覆盖前面的子元素,将前面的子子元素部分或者全部覆盖。

整个屏幕作为了一块区域,在这块区域添加多个子控件。

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <!--    帧布局
        layout_gravity:center;居中
        -->
        <TextView
            android:layout_width="300dp"
            android:layout_height="300dp"
            android:background="@color/purple"
            android:layout_gravity="center"/>
        <TextView
            android:layout_width="250dp"
            android:layout_height="250dp"
            android:background="@color/brown"
            android:layout_gravity="center"/>
        <TextView
            android:layout_width="200dp"
            android:layout_height="200dp"
            android:background="@color/blue"
            android:layout_gravity="center"/>
        <TextView
            android:layout_width="150dp"
            android:layout_height="150dp"
            android:background="@color/gold"
            android:layout_gravity="center"/>
    </FrameLayout>

5.绝对布局

绝对布局是所有控件的排列由开发人员通过控件的坐标来指定,容器不再负责管理子控件的位置。

AbsoluteLayout:子控件的位置和布局都需要通过坐标来指定,所以,在设计布局时候,需要开发人员提供子元素精确的横坐标和纵坐标。

绝对布局由坐标控制,缺乏灵活性,维护起来不容易。

layout_x: x坐标;

layout_y:y坐标;

手机上的坐标原点同pc端一样,都是在屏幕的左上角。

<AbsoluteLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    <!--绝对布局-->
        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="我是绝对布局"/>
        <Button
            android:layout_width="200px"
            android:layout_height="wrap_content"
            android:layout_x="300px"
            android:layout_y="300px"
            android:text="开始游戏"/>
    </AbsoluteLayout>


目录
相关文章
|
6天前
|
Linux 编译器 Android开发
FFmpeg开发笔记(九)Linux交叉编译Android的x265库
在Linux环境下,本文指导如何交叉编译x265的so库以适应Android。首先,需安装cmake和下载android-ndk-r21e。接着,下载x265源码,修改crosscompile.cmake的编译器设置。配置x265源码,使用指定的NDK路径,并在配置界面修改相关选项。随后,修改编译规则,编译并安装x265,调整pc描述文件并更新PKG_CONFIG_PATH。最后,修改FFmpeg配置脚本启用x265支持,编译安装FFmpeg,将生成的so文件导入Android工程,调整gradle配置以确保顺利运行。
24 1
FFmpeg开发笔记(九)Linux交叉编译Android的x265库
|
29天前
|
Java Android开发
Android 开发获取通知栏权限时会出现两个应用图标
Android 开发获取通知栏权限时会出现两个应用图标
14 0
|
1月前
|
XML 缓存 Android开发
Android开发,使用kotlin学习多媒体功能(详细)
Android开发,使用kotlin学习多媒体功能(详细)
103 0
|
1月前
|
设计模式 人工智能 开发工具
安卓应用开发:构建未来移动体验
【2月更文挑战第17天】 随着智能手机的普及和移动互联网技术的不断进步,安卓应用开发已成为一个热门领域。本文将深入探讨安卓平台的应用开发流程、关键技术以及未来发展趋势。通过分析安卓系统的架构、开发工具和框架,本文旨在为开发者提供全面的技术指导,帮助他们构建高效、创新的移动应用,以满足不断变化的市场需求。
18 1
|
1月前
|
机器学习/深度学习 调度 Android开发
安卓应用开发:打造高效通知管理系统
【2月更文挑战第14天】 在移动操作系统中,通知管理是影响用户体验的关键因素之一。本文将探讨如何在安卓平台上构建一个高效的通知管理系统,包括服务、频道和通知的优化策略。我们将讨论最新的安卓开发工具和技术,以及如何通过这些工具提高通知的可见性和用户互动性,同时确保不会对用户造成干扰。
33 1
|
3天前
|
数据库 Android开发 开发者
安卓应用开发:构建高效用户界面的策略
【4月更文挑战第24天】 在竞争激烈的移动应用市场中,一个流畅且响应迅速的用户界面(UI)是吸引和保留用户的关键。针对安卓平台,开发者面临着多样化的设备和系统版本,这增加了构建高效UI的复杂性。本文将深入分析安卓平台上构建高效用户界面的最佳实践,包括布局优化、资源管理和绘制性能的考量,旨在为开发者提供实用的技术指南,帮助他们创建更流畅的用户体验。
|
20天前
|
XML 开发工具 Android开发
构建高效的安卓应用:使用Jetpack Compose优化UI开发
【4月更文挑战第7天】 随着Android开发不断进化,开发者面临着提高应用性能与简化UI构建流程的双重挑战。本文将探讨如何使用Jetpack Compose这一现代UI工具包来优化安卓应用的开发流程,并提升用户界面的流畅性与一致性。通过介绍Jetpack Compose的核心概念、与传统方法的区别以及实际集成步骤,我们旨在提供一种高效且可靠的解决方案,以帮助开发者构建响应迅速且用户体验优良的安卓应用。
|
22天前
|
监控 算法 Android开发
安卓应用开发:打造高效启动流程
【4月更文挑战第5天】 在移动应用的世界中,用户的第一印象至关重要。特别是对于安卓应用而言,启动时间是用户体验的关键指标之一。本文将深入探讨如何优化安卓应用的启动流程,从而减少启动时间,提升用户满意度。我们将从分析应用启动流程的各个阶段入手,提出一系列实用的技术策略,包括代码层面的优化、资源加载的管理以及异步初始化等,帮助开发者构建快速响应的安卓应用。
|
22天前
|
Java Android开发
Android开发之使用OpenGL实现翻书动画
本文讲述了如何使用OpenGL实现更平滑、逼真的电子书翻页动画,以解决传统贝塞尔曲线方法存在的卡顿和阴影问题。作者分享了一个改造后的外国代码示例,提供了从前往后和从后往前的翻页效果动图。文章附带了`GlTurnActivity`的Java代码片段,展示如何加载和显示书籍图片。完整工程代码可在作者的GitHub找到:https://github.com/aqi00/note/tree/master/ExmOpenGL。
25 1
Android开发之使用OpenGL实现翻书动画
|
22天前
|
Android开发 开发者
Android开发之OpenGL的画笔工具GL10
这篇文章简述了OpenGL通过GL10进行三维图形绘制,强调颜色取值范围为0.0到1.0,背景和画笔颜色设置方法;介绍了三维坐标系及与之相关的旋转、平移和缩放操作;最后探讨了坐标矩阵变换,包括设置绘图区域、调整镜头参数和改变观测方位。示例代码展示了如何使用这些方法创建简单的三维立方体。
18 1
Android开发之OpenGL的画笔工具GL10