Visual Studio跨平台开发实战(4):Xamarin Android控制项介绍
liuian 2025-05-10 23:17 91 浏览
前言
不同于iOS, Xamarin 在Visual Studio中针对Android, 可以直接设计使用者界面. 在本篇教学文章中, 笔者会针对Android的专案目录结构以及基本控制项进行介绍, 包含TextView, EditView, Toggle/ Switch以及Seekbar控制项.
Android 专案目录结构
在Visual Studio建立Android 应用程序专案后, 在方案总览中会看到如下图的目录结构:
Assets:放置在Assets文件夹中的文件, 将会一起被封装进Android的封装文档中(建构动作设定为"AndroidAsset"). 之后便可以通过如下的陈述式来存取Assets的资源。
| 1 | public class ReadAsset : Activity |
| 5 | protected override void OnCreate (Bundle bundle) { |
| 9 | InputStream input = Assets.Open ("my_asset.txt");}} |
Resources:包含Drawable, Layout以及Values文件夹. Drawable用来放置图片. 依照设备的解析度不同, 还可以新增drawable-hdpi, drawable-mdpi, drawable-ldpi等文件夹来存放不同解析度的文件. Layout文件夹则是存放使用者界面文档(副文档名为.axml). 而Value文件夹则是可以存放不同类别的XML对应文档, 例如styles.xml, colors.xml… 针对Resources底下的文件, 动作请设定为”AndroidResource”
若您开启预设的Main.axml, 会看到如同下面的XML描述
- LinearLayout: 主要的页面框架, 以垂直或水平的方式排列页面上的对象, 相当于Silverlight 中的stack panel
- @+id/[对象名称]: 告诉Android parser, 为对象建立一个resource id
- @string/[名称]: 在String.xml中建立一个字符串资源, 后续可供Resource类别存取.
上述的@string则会对应到文件夹Resources\Values\String.xml
- 名称Hello对应到UI中Button的Text属性
- 名称ApplicationName对应到专案属性中的应用程序名称
- 名称Hello2为自行定义的字符串资源.
有了以上的基本概念后, 接下来我们来介绍Android的基本控制项。
TextView
1. 开启Lab03-BasicControls 专案并开启Layout文件夹下的TextView.axml
2. 从左边的工具列将TextView拖放到画面中, 双击TextView并编辑文字
3. 接着拖拉一个TextView, 并在右边的属性视窗设定textcolor为#2A3748, textsize为24dip
4. 再拖拉一个TextView并输入文字, 包含一个超链接. 在属性中将autolink的属性值改为web.
结果如下:链接文字会自动变成超链接.
5. 最后拖拉一个TextView并输入文字, 包含超过5位数的数字, 在属性中将autolink的属性值改为phone
结果如下: 数字被更改为超链接
6. 开启TextViewScreen.cs 并在OnCreate 事件中载入Layout中的TextView
SetContentView(Resource.Layout.TextView);
7. 执行专案并检视及操作有链接的TextView內容.
EditText
1. 开启Layout文件夹下的EditText.axml
2. 从工具箱中拖拉1个Text(Small)及1个Plain Text对象到画面上并编辑Text的文字如下:
将属性中的autoText设为true
3. 拖拉一组Text及Plain Text对象到画面上并编辑Text的文字如下:
将属性中的capitalize设为words.
4. 拖拉一组Text及password对象到画面上并编辑Text的文字如下:
5. 开启EditTextScreen.cs 并在OnCreate 事件中载入Layout中的TextView
SetContentView(Resource.Layout.EditText);
6. 执行专案, 在第一个栏位输入错的单字, 将会出现拼字错误及建议视窗.
7. 其他栏位效果如下:
Switch / Toggle button
Switch跟Toggle其实是很相似的控制项, 都是控制开和关的选项, 但显示的方式有所不同. 我们在同一个练习中使用这2个控制项. (注: Switch控制项是在Android 4.0(API14)后才有, 因此在工具箱中找不到此控制项, 必须在XML中自行输入. 此外, 您的模拟器也必须是Android 4.0以上才能执行)
1. 开启SwitchToggle.axml. 在画面上依序部署1个TextView, 用来显示讯息, 1个ToggleButton以及1个Switch控制项. 如下图所示:
Axml的声明如下, 请微调部分属性:
| 01 | http://schemas.android.com/apk/res/android" |
| 03 | android:orientation="vertical" |
| 05 | android:layout_width="fill_parent" |
| 07 | android:layout_height="fill_parent"> |
| 11 | android:textAppearance="?android:attr/textAppearanceMedium" |
| 13 | android:layout_width="fill_parent" |
| 15 | android:layout_height="wrap_content" |
| 17 | android:id="@+id/textView1"/> |
| 21 | android:layout_width="fill_parent" |
| 23 | android:layout_height="wrap_content" |
| 25 | android:id="@+id/toggleButton1" |
| 31 | android:layout_marginBottom="6.7dp"/> |
| 35 | android:layout_width="fill_parent" |
| 37 | android:layout_height="wrap_content" |
| 45 | android:layout_marginRight="225.3dp"/> |
2. 开启SwitchToggleScreen.cs. 并编写以下代码.
| 03 | SetContentView(Resource.Layout.SwitchToggle); |
| 07 | ToggleButton toggle = FindViewById(Resource.Id.toggleButton1); |
| 09 | Switch _switch = FindViewById(Resource.Id.Switch1); |
| 11 | TextView msg = FindViewById(Resource.Id.textView1); |
| 13 | //处理Toggle Button的Click事件, 并将状态显示在TextView |
| 15 | toggle.Click+= (sender, e) => { |
| 19 | msg.Text = "目前Toggle Button的状态是\"开\"";} |
| 23 | msg.Text = "目前Toggle Button的状态是\"关\"";};}; |
| 25 | //处理Switch的Click事件, 并将状态显示在TextView |
| 27 | _switch.Click += (sender, e) => { |
| 31 | msg.Text = "目前Switch Button的状态是\"开\"";} |
| 35 | msg.Text = "目前Switch Button的状态是\"关\"";};}; |
Toggle Button及Switch 控制项的操作几乎完全相同, 主要就是处理控制项的click事件并判断目前的开关状况.
3. 执行专案并检视执行结果.
Seek Bar
1. 开启seekBar.axml并从工具箱拖放TextView及SeekBar控制项进银幕
界面声明的xml如下:
| 27 | android:layout_marginTop="48.0dp"/> |
2. 开启SeekBarScreen.cs并在OnCreate事件中编写以下代码:
| 03 | SetContentView(Resource.Layout.SeekBar); |
| 07 | var msg = FindViewById(Resource.Id.textView1); |
| 09 | var seekbar = FindViewById(Resource.Id.seekBar1); |
| 15 | //处理SeekBar的ProgressChanged事件, 并将目前的大小(进度)通过extView呈现 |
| 17 | seekbar.ProgressChanged += (sender, e) => { |
| 19 | msg.Text = string.Format("目前Seekbar的大小为{0}", seekbar.Progress.ToString); |
SeekBar的操作非常的直截. 您只需要处理SeekBar控制项的ProgressChanged事件即可.
3. 执行专案并检视执行结果.
结语
Android 的开发方式, 与先前介绍的iOS略有不同. iOS通过Outlet及Action将View及Controller进行连接. 而Android 则是通过Parser, 为页面上的控制项建立id属性, 让Activity可以通过FindViewById方式建立控制项的对象实体, 接下来的处理方式就与iOS或Windows Form在操作控制项的方式类似. 在下一篇教学文章中, 将说明Android应用程序的多页面处理.
本站文章除注明转载外,均为本站原创或翻译
相关推荐
- 联想售后服务公司大全(联想各大服务售后地址)
-
方法如下:使用电脑打开QQ浏览器。打开浏览器以后,使用搜索引擎搜索联想,找到官方网站。点击打开官方网站,将鼠标放在服务选项上,弹出界面的左侧可以看到服务网点查询选项,点击该选项会自动定位用户所在的位置...
- oem win10(oem win10 换硬盘)
-
我不能对Windows10OEM版本做出评价。但是,OEM版本通常比零售版本便宜且功能相同,但可能在支持和保修方面有所区别。总的来说,购买合法,适合您的操作系统版本是最重要的。wⅰn10的OEM版...
- 为什么系统重装不了(系统重装不了的n种情况)
-
1、首先看电脑里是不是安装了其他版本的office,如果之前安装有的话,要卸载之前的版本。1.重新安装office,选择“添加或删除功能”,点“下一步”;2.“选择应用程序的高级自定义”,然后你会...
- w10如何定时关机(win10怎么样定时关机)
-
进入“电脑属性”。右键点击“此电脑”图标——“属性”,进入“电脑属性”。进入“控制面板主页”。点击左侧“控制面板主页”,进入“控制面板主页”。进入“系统和安全”设置。点击“系统和安全”,进入“系统和安...
- fast路由器地址(fast路由器ip地址)
-
fast路由器的登录地址(管理页面地址)是falogin.cn,电脑、手机连接到fast路由器的网络后,在浏览器中输入falogin.cn,就可以进入到fast路由器的登录页面。在登录页面中,输入正确...
- 电脑进不去桌面怎么重新安装系统
-
把一个系统放到桌面的方法方法1在桌面上空白处单击鼠标右键,在弹出的快捷菜单中选择【个性化】菜单命令2弹出【个性化】窗口3选择【更改桌面图标】链接4弹出【桌面图标设置】对话框5选择要添加的桌面图标,在复...
- cad2008下载免费中文版破解版
-
1还可以。不是很难用。2比较用的多的是CAD2007和CAD2004。但实际上CAD2008也是好用的。这是大家用的少。3 CAD哪个版本比较好?其实主要看周围的人用什么版本。一般人选...
-
- windows键的功能(windows键有什么用)
-
windows键上有一个微软Windows样式的图标,Win键处于电脑键盘的左下角,处于Ctrl键与Alt键中间的那个带着微软的徽标键就是Win键,该按键属于辅助按键,主要与其它按键组合使用,实现一些特定的功能,配合Win键可以和其他按键组...
-
2025-12-26 10:55 liuian
-
- 一键恢复照片免费(一键恢复照片免费版app)
-
如何一键还原涂鸦图片?1、涂鸦的作用就是为破坏其背后图像的细节,利用ps软件里面的修复画笔工具、修补工具和仿制图章工具,根据不同污点大小选择不同工具,可以还原部分图片。2、对于涂鸦严重的照片是无法还原,利用美图秀秀还原涂鸦图片,如果是涂鸦后...
-
2025-12-26 10:05 liuian
- 快捷方式小箭头怎么去除(快捷方式小箭头怎么去除图标)
-
要去除Windows桌面快捷方式的小箭头,可以按照以下步骤操作:针对Windows7、8、10系统:1.**通过注册表编辑器去除**: -按`Win+R`键打开“...
- qq网页版登录后怎么聊天(qq聊天网页版电脑登录)
-
两种方法:1对方知道的情况下:让对方把她的Tencent\QQ\(QQ号码)\Msgex.db文件发送给你,你先用对方的qq登陆一次,然后替换调Tencent\QQ\(QQ号码)\Msgex.db文...
- 免费全局主题商店(主题商店的全局主题是什么意思)
-
vivo手机下载免费全局主题方法:进入手机自带的i主题-主题中的搜索框输入“免费”,在主题中找到免费的全局主题下载应用即可。具体操作步骤(以vivoX20为例):1、待机桌面进入i主题2、主题...
- 怎么取消电脑自动更新(怎么取消电脑自动更新win10)
-
如果您想临时关闭Windows计算机的自动更新功能,可以按照以下步骤操作:1.打开“设置”应用程序。您可以点击Windows菜单并选择“设置”选项,或者使用Win+I快捷键打开“设置...
- 如何安装cad2014(如何安装监控摄像头视频教程)
-
安装AutoCAD2014的步骤如下:解压软件安装包。自动弹出安装面板,点击安装。选择“我接收”,点击下一步。提供三组序列号666-69696969、667-98989898、400-4545454...
- 惠普1020打印机怎么连接电脑
-
1,先安装好打印机,将打印机的连接线接到电脑上,打开打印机电源。2,打开电脑,然后使用随机的打印机驱动程序或者到打印机的官网下载当前系统的驱动程序,然后点击安装。3,安装完成后,点击打印测试页,如...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
