NOTE: see the dotnet branch for a subset of samples that have been ported to .NET 6.
This repository contains Mono for Android samples, showing usage of various Android API wrappers from C#. Visit the Android Sample Gallery to download individual samples.
The Apache License 2.0 applies to all samples in this repository.
Copyright 2011 Xamarin Inc
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
When porting a legacy sample to NET6+, please make sure to preserve as much history of the original sample as possible. Some samples have their project, source and resource files in the same directory where the readme file, screenshot folder and other files not directly related to the sample code reside. Since NET6+ defaults to importing all the files in the project directory as if they were part of the project, the application code must first be moved to a subdirectory (with the exception of the .sln file).
New subdirectory should use the same name as the solution file,
without the .sln extension. After creating it first move all the
relevant files and directories (source code, project file(s), the
Properties
and Resources
directories etc), using the git mv
command to the newly created directory, modify the .sln file to update
project file path(s) and commit these changes. This ensures that
further changes will preserve commit history.
Now the sample is ready for porting. After creating new project file
(using dotnet new android -n SampleName
) in a separate directory,
copy any necessary package and project references from the old
project, updating them as needed and after that replace the old
project file with the new one.
A handful of useful tips (copied from the dotnet
branch's README in
this repository):
- If the root namespace doesn't match the project name, to get the existing code to compile, you may need:
<RootNamespace>Xamarin.AidlDemo</RootNamespace>
- Update any dependencies, NuGet packages, etc.
- Remove android:versionCode, android:versionName, package, , and <application label="". These are defined in the .csproj file.
- Remove all unused using statements, since we now have ImplicitUsings=enable.
- Fix all namespace declarations to use C# 10 file-scoped namespaces.
- Build. Fix any warnings related to nullable reference types (Nullable=enable).
- Run the app and ensure the sample still works.
Another collection of tips can be found here
Before adding a sample to the repository, please run either install-hook.bat or install-hook.sh depending on whether you're on Windows or a POSIX system. This will install a Git hook that runs the Xamarin code sample validator before a commit, to ensure that all samples are good to go.
We love samples! Application samples show off our platform and provide a great way for people to learn our stuff. And we even promote them as a first-class feature of the docs site. You can find the sample galleries here:
These sample galleries are populated by samples in these GitHub repos:
The mobile-samples repository is for samples that are cross-platform. The mac-ios-samples repository is for samples that are Mac/iOS only.
We welcome sample submissions, please start by creating an issue with your proposal.
Because the sample galleries are powered by the github sample repos, each sample needs to have the following things:
-
Screenshots - a folder called Screenshots that has at least one screen shot of the sample on each platform (preferably a screen shot for every page or every major piece of functionality). For an example of this, see android-p/AndroidPMiniDemo.
-
Readme - a
README.md
file that explains the sample, and contains metadata to help customers find it. For an example of this, see android-p/AndroidPMiniDemo. The README file should begin with a YAML header (delimited by---
) with the following keys/values:-
name - must begin with
Xamarin.Android -
-
description - brief description of the sample (< 150 chars) that appears in the sample code browser search
-
page_type - must be the string
sample
. -
languages - coding language/s used in the sample, such as:
csharp
,fsharp
,vb
,java
-
products: should be
xamarin
for every sample in this repo -
urlFragment: although this can be auto-generated, please supply an all-lowercase value that represents the sample's path in this repo, except directory separators are replaced with dashes (
-
) and no other punctuation.
Here is a working example from android-p/AndroidPMiniDemo README raw view.
--- name: Xamarin.Android - Android P Mini Demo description: "Demonstrates new display cutout and image notification features (Android Pie)" page_type: sample languages: - csharp products: - xamarin urlFragment: android-p-androidpminidemo --- # Heading 1 rest of README goes here, including screenshot images and requirements/instructions to get it running
NOTE: This must be valid YAML, so some characters in the name or description will require the entire string to be surrounded by " or ' quotes.
-
-
Buildable solution and .csproj file - the project must build and have the appropriate project scaffolding (solution + .csproj files).
This approach ensures that all samples integrate with the Microsoft sample code browser.
A good example of this stuff is here in the Android Pie sample
For a cross-platform sample, please see: https://github.com/xamarin/mobile-samples/tree/master/Tasky
We integrate tightly with Git to make sure we always provide working samples to our customers. This is achieved through a pre-commit hook that runs before your commit goes through, as well as a post-receive hook on GitHub's end that notifies our samples gallery server when changes go through.
To you, as a sample committer, this means that before you push to the repos, you should run the "install-hook.bat" or "install-hook.sh" (depending on whether you're on Windows or macOS/Linux, respectively). These will install the Git pre-commit hook. Now, whenever you try to make a Git commit, all samples in the repo will be validated. If any sample fails to validate, the commit is aborted; otherwise, your commit goes through and you can go ahead and push.
This strict approach is put in place to ensure that the samples we present to our customers are always in a good state, and to ensure that all samples integrate correctly with the sample gallery (README.md, Metadata.xml, etc). Note that the master branch of each sample repo is what we present to our customers for our stable releases, so they must always Just Work.
Should you wish to invoke validation of samples manually, simply run "validate.windows" or "validate.posix" (again, Windows vs macOS/Linux, respectively). These must be run from a Bash shell (i.e. a terminal on macOS/Linux or the Git Bash terminal on Windows).
If you have any questions, don't hesitate to ask!