.NET MAUI is the .NET Multi-platform App UI, a framework for building native device applications spanning mobile, tablet, and desktop.
Перейти к файлу
Atsushi Eno 7d66ed0aad Android BeginInvokeOnMainThread() should not possibly block. (#343)
Android.App.Activity.RunOnUiThread() does not always run the argument
Runnable asynchronously; actually it is run synchronously if current
thread is the UI thread [*1][*2]

Use Handler.Post() instead. (It is also used in Android.App.SyncContext[*3])

[*1] https://developer.android.com/reference/android/app/Activity.html#runOnUiThread(java.lang.Runnable)
[*2] http://stackoverflow.com/questions/33039600/android-runonuithread-not-async
[*3] https://github.com/xamarin/xamarin-android/blob/5777337/src/Mono.Android/Android.App/SyncContext.cs#L15
2016-09-16 14:05:29 -07:00
.nuget Initial import 2016-03-22 16:13:41 -07:00
.nuspec Remove iOS classic from CI system (#353) 2016-09-14 22:56:17 +01:00
AndroidNative/FormsViewGroup Initial import 2016-03-22 16:13:41 -07:00
ICSharpCode.Decompiler Make resharper happier with comments 2016-04-12 09:20:13 -07:00
PagesGallery [Pages] Add reference to Xamarin.Forms.Build.Tasks (#220) 2016-06-13 09:20:58 -07:00
Stubs Remove iOS classic from CI system (#353) 2016-09-14 22:56:17 +01:00
Xamarin.Forms.Build.Tasks do not disable warning (#357) 2016-09-15 14:45:50 +02:00
Xamarin.Forms.ControlGallery.Android [Android] Fix failing UITests (#356) 2016-09-15 10:33:39 -07:00
Xamarin.Forms.ControlGallery.WP8 Enable WebView to render local HTML files on WinRT platforms (#277) 2016-08-03 14:22:14 -07:00
Xamarin.Forms.ControlGallery.Windows Enable WebView to render local HTML files on WinRT platforms (#277) 2016-08-03 14:22:14 -07:00
Xamarin.Forms.ControlGallery.WindowsPhone Enable WebView to render local HTML files on WinRT platforms (#277) 2016-08-03 14:22:14 -07:00
Xamarin.Forms.ControlGallery.WindowsUniversal Native Bindings (#278) 2016-09-08 11:39:05 -07:00
Xamarin.Forms.ControlGallery.iOS Remove iOS classic from CI system (#353) 2016-09-14 22:56:17 +01:00
Xamarin.Forms.Controls [Xaml] support native views and native bindings (#266) 2016-09-08 11:45:43 -07:00
Xamarin.Forms.Controls.Issues/Xamarin.Forms.Controls.Issues.Shared [Android] Fix failing UITests (#356) 2016-09-15 10:33:39 -07:00
Xamarin.Forms.Core Revert "[C] Prevent enabling a Button via setting a Command (#308)" 2016-09-13 12:34:22 +01:00
Xamarin.Forms.Core.Android.UITests [iOS] Change when we updated the XF INavigationPageController after popping a page natively, Cleanup UITest references (#291) 2016-08-16 11:31:53 -07:00
Xamarin.Forms.Core.Design Warnings as Errors in product projects 2016-04-06 10:32:29 -07:00
Xamarin.Forms.Core.UnitTests [Xaml] support native views and native bindings (#266) 2016-09-08 11:45:43 -07:00
Xamarin.Forms.Core.Windows.UITests [UITest] Update to 1.3.8, remove old projects (#240) 2016-06-24 17:05:42 +01:00
Xamarin.Forms.Core.iOS.UITests [iOS] Change when we updated the XF INavigationPageController after popping a page natively, Cleanup UITest references (#291) 2016-08-16 11:31:53 -07:00
Xamarin.Forms.CustomAttributes Add TextColor Property to Picker, TimePicker, DatePicker (#84) 2016-04-19 00:01:58 -07:00
Xamarin.Forms.Maps Prepare Preserve attribute usage for removal of InternalsVisibleTo (#121) 2016-04-26 11:20:55 -04:00
Xamarin.Forms.Maps.Android Format MapRenderer according to project code style (#362) 2016-09-16 19:55:38 +01:00
Xamarin.Forms.Maps.Design Warnings as Errors in product projects 2016-04-06 10:32:29 -07:00
Xamarin.Forms.Maps.UWP Mop up enabling warnings as errors (#78) 2016-04-12 11:44:30 -07:00
Xamarin.Forms.Maps.WP8 Maps.WP8 warning as error mop up (#79) 2016-04-13 17:15:21 +01:00
Xamarin.Forms.Maps.WinRT.Phone Mop up enabling warnings as errors (#78) 2016-04-12 11:44:30 -07:00
Xamarin.Forms.Maps.WinRT.Tablet Mop up enabling warnings as errors (#78) 2016-04-12 11:44:30 -07:00
Xamarin.Forms.Maps.iOS Remove iOS classic from CI system (#353) 2016-09-14 22:56:17 +01:00
Xamarin.Forms.Pages XF.Pages MS.Bcl.Build v1.0.14 -> v1.0.21 (#187) 2016-05-26 12:26:13 -07:00
Xamarin.Forms.Pages.Azure Azure support (#143) 2016-04-27 14:48:28 -04:00
Xamarin.Forms.Pages.UnitTests Prep Cell & friends for removal of InternalsVisibleTo (#142) 2016-06-17 11:10:18 +01:00
Xamarin.Forms.Platform Remove ToolBar from Core; Remove ToolBar renderers and unit tests (#124) 2016-04-25 12:52:48 -04:00
Xamarin.Forms.Platform.Android Android BeginInvokeOnMainThread() should not possibly block. (#343) 2016-09-16 14:05:29 -07:00
Xamarin.Forms.Platform.Android.AppLinks Evolve feature branch (#117) 2016-04-24 12:25:26 -04:00
Xamarin.Forms.Platform.Android.FormsViewGroup Warnings as Errors in product projects 2016-04-06 10:32:29 -07:00
Xamarin.Forms.Platform.UAP [Xaml] support native views and native bindings (#266) 2016-09-08 11:45:43 -07:00
Xamarin.Forms.Platform.WP8 KeyboardExtensions is now public (#326) 2016-08-30 11:31:41 -07:00
Xamarin.Forms.Platform.WinRT After Label.FormattedText property changed need invoke UpdateText method (#335) 2016-09-12 12:52:31 +01:00
Xamarin.Forms.Platform.WinRT.Phone Fix incorrect background property name on Win 8.1 phone and tablet styles (#329) 2016-08-31 12:57:35 -07:00
Xamarin.Forms.Platform.WinRT.Tablet Fix incorrect background property name on Win 8.1 phone and tablet styles (#329) 2016-08-31 12:57:35 -07:00
Xamarin.Forms.Platform.iOS Remove iOS classic from CI system (#353) 2016-09-14 22:56:17 +01:00
Xamarin.Forms.Xaml [Xaml] support native views and native bindings (#266) 2016-09-08 11:45:43 -07:00
Xamarin.Forms.Xaml.Design Enable warnings as errors in XAML 2016-04-06 23:08:17 -07:00
Xamarin.Forms.Xaml.UnitTests [XamlC] throw exception on missing property (#336) 2016-09-08 21:01:09 +02:00
Xamarin.Forms.Xaml.Xamlc Enable warnings as errors in XAML 2016-04-06 23:08:17 -07:00
Xamarin.Forms.Xaml.Xamlg Enable warnings as errors in XAML 2016-04-06 23:08:17 -07:00
docs Update docs 2016-09-13 09:57:19 -07:00
tools/mdoc Add missing mdoc tooling 2016-03-22 17:28:19 -07:00
.editorconfig Added .editorconfig (#192) 2016-05-26 13:39:00 -07:00
.gitattributes Initial import 2016-03-22 16:13:41 -07:00
.gitignore Ignore TabsStudio file 2016-04-25 16:09:52 -07:00
LICENSE Fix license copy 2016-04-29 13:41:50 -04:00
Makefile Update Makefile to support linux env (#309) 2016-08-30 10:55:00 -07:00
PULL_REQUEST_TEMPLATE.md Update PULL_REQUEST_TEMPLATE.md 2016-03-23 10:42:54 -07:00
README.md Update README.md 2016-05-03 16:52:51 -04:00
Xamarin.Forms.mdpolicy Add Xamarin.Forms code policy file for XamarinStudio 2016-03-28 15:39:31 +01:00
Xamarin.Forms.sln Remove iOS classic from CI system (#353) 2016-09-14 22:56:17 +01:00
Xamarin.Forms.sln.DotSettings [Android] Memory leak when MasterDetailPage Detail set to NavigationPage (#239) 2016-06-27 09:20:47 -06:00
Xamarin.Forms.vssettings Update vssettings file to turn on Wrapping_PreserveSingleLine (#115) 2016-04-24 05:56:36 -07:00
debug.keystore Add missing debug.keystore 2016-03-22 18:07:44 -07:00
update-docs-windows.bat Evolve feature branch (#117) 2016-04-24 12:25:26 -04:00
update-docs.ps1 Normalize docs (#159) 2016-05-11 15:41:05 +01:00
verify-nuspecs.ps1 Initial import 2016-03-22 16:13:41 -07:00

README.md

Xamarin.Forms

Xamarin.Forms provides a way to quickly build native apps for iOS, Android, and Windows, completely in C#.

Read more about the platform at https://www.xamarin.com/forms.

Getting Started

Install Visual Studio 2015

VS 2015 is required for developing Xamarin.Forms. If you do not already have it installed, you can download it here. VS 2015 Community is completely free. If you are installing VS 2015 for the first time, select the "Custom" installation type and select the following from the features list to install:

  • C#/.NET (Xamarin v4.0.3)
  • Universal Windows App Development Tools
  • Windows 8.1 and Windows Phone 8.0/8.1 Tools

We also recommend installing Microsoft Visual Studio Emulator for Android as well as Emulators for Windows Phone 8.1. If you already have VS 2015 installed, you can verify that these features are installed by modifying the VS 2015 installation via the Control Panel.

Install Additional Features

After installing VS 2015, you will also need to install the following:

  • Bing Maps SDK for Windows 8.1 Store apps -- you can find this in Tools > Extensions and Updates and searching for "bing" in the Online pane.
  • Android SDKs -- you can install these via Tools > Android > Android SDK Manager.
Solution Configuration

Upon opening the Xamarin.Forms solution, you will find that there are a number of errors and warnings under the Error List pane; you can resolve this by changing the filter of Build + IntelliSense to Build Only. At this point, you should be able to successfully build the solution.

By default, the Xamarin.Forms.Controls project does not have a configuration for various API keys to access certain features on each platform (e.g. maps). When building the solution the first time, a controlgallery.config file will be generated inside that project, which looks like this:

Win8MapsAuthKey:
WinPhoneMapsAuthKey:
UWPMapsAuthKey:
InsightsApiKey:
WP8AppId:
WP8AuthToken:

You will have to obtain your own API keys for each of these services, inserted directly after the identifier (e.g. Win8MapsAuthKey:abcdefghijklmnopqrstuvwxyz). You can find out how to obtain each of these as follows:

Due to the way that Android works, the maps API key cannot be injected at runtime. As a result, you will have to add this key to the MapsKey.cs file under Xamarin.Forms.ControlGallery.Android/Properties:

[assembly: Android.App.MetaData("com.google.android.maps.v2.API_KEY", Value = "INSERT_KEY_HERE")]

You can find out how to obtain a Google Maps API key here.

Coding Style

We follow the style used by the .NET Foundation, with two primary exceptions:

  • We do not use the private keyword as it is the default accessibility level in C#.
  • We use hard tabs over spaces. You can change this setting in VS 2015 via Tools > Options and navigating to Text Editor > C# and selecting the "Keep tabs" radio option.

Contributing

Mailing Lists

To discuss this project, and participate in the design, we use the forms-devel@lists.xamarin.com mailing list.

Reporting Bugs

We use Bugzilla to track issues.