什么是 Xamarin Forms ?

Xamarin Forms 是一个高效创建跨平台用户界面的库 。通过Xamarin Forms 能够一次编码生成基于主流移动平台(iOS, Android, Windows Phone)的应用界面。和HTML 5 不同, 它是一套原生的界面解决方式,这意味着通过Xamarin
Forms 渲染的界面是与底层API 紧密相连, 那你能够结合诸如iOS 中的Core Motion , PassKit 还有StoreKit 这些API 使用 ,也能够使用诸如NFC / Google Play Service 的Android API ,当然少不了Windows Phone 的Tiles 。

Xamarin Forms 的优势

通过一次编码,生成多平台界面。假若你做的工作涉及到三个平台,那你会对重反复复的界面逻辑工作厌烦,Xamarin Forms 真的是一个不错的解决方式。

使用 Xamarin Forms 

你能够通过C#硬编码方式去架构你的界面,还有你能够通过XAML方式去构建。

Xamarin Forms 能适配的界面

Pages (页面)

Layout(布局)

Controls(控件)

好来看看一个简单的样例,因为这篇文章仅仅是初探,我仅仅会把部分精彩的节录下来,大家能够下载代码细看。假设要探究就继续关注我的blog , 接下来会陆续有关于Xamarin Forms 的更深入文章。

1. 创建Xamarin.Forms 项目

这里须要说明一点,Xamarin Forms项目有两种模版一种是基于Share Project ,一种是基于PCL ,这里要看各自项目的须要,我默认选取PCL(关于两个模版的使用,我会在之后文章和大家说说)

2. 创建成功后,会生成包括CnBetaDemo.Shared,CnBetaDemo.iOS, CnBetaDemo.Android 三个项目(假设你用Visual Studio 创建你就会有CnBetaDemo.Windows Phone 的项目) 。 CnBetaDemo.Shared就是我们须要处理的共享逻辑层和Xamarin.Forms。其余两个就是我们所须要相应的平台。

3.根据MVVM 方式架构我们的CnBetaDemo.Shared , 这里不得不提到Xamarin 的原理 。Xamarin 是一个基于共享逻辑层的跨平台原生应用方案。

为何用MVVM 在我之前文章有所提及。(博客决定放到csdn,我会迁移后贴上地址)。之前一年的做法是把逻辑共享,如今能够把页面通过Xamarin.Forms进行构造就可以,所以CnBetaDemo.Shared就成为了我们跨平台架构项目的核心代码层。

4.  简单看看ViewModel层 ,这里我以读取CnBeta RSS 为例 ,FeedViewModel 的一些主要代码:

主要通过async和await 的方式载入数据

		private async Task ExecuteLoadItemsCommand()
{
if (isBusy)
return; IsBusy = true; try{ var httpClient = new HttpClient(); var feed="http://cnbeta.feedsportal.com/c/34306/f/624776/index.rss"; var responseString = await httpClient.GetStringAsync(feed); FeedItems.Clear(); var items= await ParseFeed(responseString); foreach(var item in items)
{ //Console.WriteLine(item.Title);
FeedItems.Add(item);
}
}
catch(Exception ex){ var page = new ContentPage (); var result = page.DisplayAlert ("出错 ", "载入失败.", "确认", null); } IsBusy = false; }
                private async Task<List<FeedItem>> ParseFeed(string rss)
{
return await Task.Run (() => {
var xdoc=XDocument.Parse(rss); var id=0; return ( from item in xdoc.Descendants("item")
select new FeedItem
{
Title = (string)item.Element("title"),
Description=(string)item.Element("description"),
PublishDate=(string)item.Element("pubDate"),
Id= id++
}).ToList();
});
}

5. 通过Xamarin Forms 构造View

这里须要创建一个简单的表单ListView, 和自己定义Cell, 当然Xamarin Forms会依然平台进行对应渲染生成原生的表单支持

	public class FeedView : ContentPage
{
private FeedViewModel ViewModel{
get { return BindingContext as FeedViewModel; }
} public FeedView ()
{ BindingContext = new FeedViewModel (); var stack = new StackLayout {
Orientation= StackOrientation.Vertical,
Padding = new Thickness(0,8,0,8)
}; var listView = new ListView (); listView.ItemsSource = ViewModel.FeedItems; var cell = new DataTemplate (typeof(ListTextCell)); cell.SetBinding (TextCell.TextProperty, "Title"); cell.SetBinding (TextCell.DetailProperty, "PublishDate"); listView.ItemTemplate = cell; stack.Children.Add (listView); Content = stack;
} protected override void OnAppearing()
{
base.OnAppearing (); if (ViewModel == null || !ViewModel.CanLoadMore || ViewModel.IsBusy || ViewModel.FeedItems.Count > 0)
return; ViewModel.LoadItemsCommand.Execute (null);
}
}

6. 执行看看

非常Cool吧 !!哈哈!! 欢迎大家下载我的代码看看 点击下载

对于Xamarin 本人一直非常推崇,有了Xamarin Forms更如虎添翼。这里须要排除价格,当然假设是在企业真的能够节省不少。或者你是一个Objective-C 的支持者, 或者是一个Java开发Android的深度码农,可是无可否认Xamarin 能够解决得很多其它。

非常开心在CSDN和大家分享,接下来博客在这里安家,也希望大家多和我交流,谢谢!

Xamarin.Forms 初探的更多相关文章

  1. 老司机学新平台 - Xamarin Forms开发框架二探 (Prism vs MvvmCross)

    在上一篇Xamarin开发环境及开发框架初探中,曾简单提到MvvmCross这个Xamarin下的开发框架.最近又评估了一些别的,发现老牌Mvvm框架Prism现在也支持Xamarin Forms了, ...

  2. 【转】Xamarin Forms 介绍

    特此声明,本篇博文转自:http://blog.csdn.net/kinfey/article/details/29621381 什么是 Xamarin Forms ? Xamarin Forms 是 ...

  3. xamarin.forms新建项目android编译错误

    vs2015 update3 新建的xamarin.forms项目中的android项目编译错误.提示缺少android_m2repository_r22.zip,96659D653BDE0FAEDB ...

  4. Xamarin.Forms 简介

    An Introduction to Xamarin.Forms 来源:http://developer.xamarin.com/guides/cross-platform/xamarin-forms ...

  5. Xamarin.Forms 免费电子书

    Xamarin Evolve 正在举行,现在已经放出2本免费的Xamarin.Forms 免费电子书,据现场的同学说这两天还有Xamarin.Forms 重磅消息发布: Creating Mobile ...

  6. 老司机学新平台 - Xamarin Forms开发框架之MvvmCross插件精选

    在前两篇老司机学Xamarin系列中,简单介绍了Xamarin开发环境的搭建以及Prism和MvvmCross这两个开发框架.不同的框架,往往不仅仅使用不同的架构风格,同时社区活跃度不同,各种功能模块 ...

  7. 使用Xamarin.Forms平台开发移动应用指南

    下载书:链接: http://pan.baidu.com/s/1c29H9KG 密码: 7esm 注:捣鼓虚拟机把Hyper-V关闭,后来Xamarin搞挂了,所以暂停翻译. 第1章 Xamarin. ...

  8. Xamarin.Forms.Platform.Perspex, Xamarin Forms 的 Perspex(号称下一代WPF) 实现

    Perspex, 跨平台的UI框架,加上Xamarin Forms的跨平台的中间层,这样同一套代码就可跨几乎所有已知平台,这其中包括旧版Windows, Linux及Mac OS. 目前,基本控件可显 ...

  9. 为 Xamarin.Forms 做个跑马灯控件

    前段时间,私下用 Xamarin.Forms 做了个商业项目的演示版.很多被国内App玩坏了的控件/效果,XF上都没有或是找不到对应的实现,没有办法只能亲自上阵写了几个,效果还行,就是有BUG. 这个 ...

随机推荐

  1. 玩转web之javaScript(五)---js和jquery一些不可不知的方法(input篇)

    很多时候我们都利用js和jquery中操作input,比如追加属性,改变属性值等等,我在这里简单的整理了一下,并在以后逐步补充. 1:删除input的某一属性. <input name=&quo ...

  2. linux经常使用解压缩命令

    1.tar.gz 解压 tar -zxvf source.tar.gz 压缩 tar -zcvf target.tar.gz source1 source2 2.bz2 解压 tar -jxvf so ...

  3. [置顶] ios 一个不错的图片浏览分享框架demo

    demo功能:一个不错的图片浏览分享框架demo.iphone6.1 测试通过.可以浏览图片,保存,微博分享到新浪,腾讯,网易,人人等. 注:(由于各个微博的接口有时候会有调整,不一定能分享成功.只看 ...

  4. git 常用命令及问题解决(转)

    git init 产生的目录解释error: src refspec master does not match any.引起该错误的原因是,目录中没有文件,空目录是不能提交上去的error: ins ...

  5. WPF技术触屏上的应用系列(四): 3D效果图片播放器(图片立体轮放、图片立体轮播、图片倒影立体滚动)效果实现

    原文:WPF技术触屏上的应用系列(四): 3D效果图片播放器(图片立体轮放.图片立体轮播.图片倒影立体滚动)效果实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7 ...

  6. nginx lua redis 访问频率限制(转)

    1. 需求分析 Nginx来处理访问控制的方法有多种,实现的效果也有多种,访问IP段,访问内容限制,访问频率限制等. 用Nginx+Lua+Redis来做访问限制主要是考虑到高并发环境下快速访问控制的 ...

  7. Codeforces Helpful Maths

    Xenia the beginner mathematician is a third year student at elementary school. She is now learning t ...

  8. 大约C++ const 全面总结

    C++中的const关键字的使用方法很灵活,而使用const将大大改善程序的健壮性,本人依据各方面查到的资料进行总结例如以下,期望对朋友们有所帮助. Const 是C++中经常使用的类型修饰符,常类型 ...

  9. .net RPC框架选型(一)

    近期开始研究分布式架构,会涉及到一个最核心的组件:RPC(Remote Procedure Call Protocol).这个东西的稳定性与性能,直接决定了分布式架构系统的好坏.RPC技术,我们的产品 ...

  10. Linux查看命令终止进程

    Linux查看命令终止进程 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ ps PID TTY TIME CMD 2576 pts/0 00:00:00 ba ...