Visual Studio跨平台开发实战(4):Xamarin Android控制项介绍
wptr33 2025-06-12 16:45 23 浏览
前言
不同于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应用程序的多页面处理.
本站文章除注明转载外,均为本站原创或翻译
相关推荐
- oracle数据导入导出_oracle数据导入导出工具
-
关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...
- 继续学习Python中的while true/break语句
-
上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...
- python continue和break的区别_python中break语句和continue语句的区别
-
python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...
- 简单学Python——关键字6——break和continue
-
Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
-
用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...
- Python 中 break 和 continue 傻傻分不清
-
大家好啊,我是大田。...
- python中的流程控制语句:continue、break 和 return使用方法
-
Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...
- L017:continue和break - 教程文案
-
continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...
- 作为前端开发者,你都经历过怎样的面试?
-
已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...
- 面试被问 const 是否不可变?这样回答才显功底
-
作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...
- 2023金九银十必看前端面试题!2w字精品!
-
导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...
- 前端面试总结_前端面试题整理
-
记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...
- 由浅入深,66条JavaScript面试知识点(七)
-
作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...
- 2024前端面试真题之—VUE篇_前端面试题vue2020及答案
-
添加图片注释,不超过140字(可选)...
- 今年最常见的前端面试题,你会做几道?
-
在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...
- 一周热门
- 最近发表
-
- oracle数据导入导出_oracle数据导入导出工具
- 继续学习Python中的while true/break语句
- python continue和break的区别_python中break语句和continue语句的区别
- 简单学Python——关键字6——break和continue
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
- Python 中 break 和 continue 傻傻分不清
- python中的流程控制语句:continue、break 和 return使用方法
- L017:continue和break - 教程文案
- 作为前端开发者,你都经历过怎样的面试?
- 面试被问 const 是否不可变?这样回答才显功底
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)
