Xamarin.iOS sample apps
Перейти к файлу
TJ Lambert ae5c15ae32 fix spacing 2020-10-28 14:40:29 -05:00
.vscode Create settings.json 2019-07-19 19:12:39 -07:00
AQTapDemo Update README.md 2019-10-23 10:33:02 -07:00
AUSoundTriggeredPlayingSoundMemoryBased
AVCompositionDebugVieweriOS
AVCustomEdit
AVTouchSample
AdaptiveElements
AirLocate
AppPrefs
Appearance
ApplicationFundamentals onboard missing samples 2019-08-02 10:53:41 -07:00
AsyncDownloadImage
AudioConverterFileConverter Update README.md 2019-10-23 09:59:32 -07:00
AudioGenerator onboard missing samples 2019-08-01 19:56:58 -07:00
AudioQueueOfflineRenderDemo
AudioTapProcessor
BackgroundExecution
BindingSample
BouncingGameCompleteiOS
BouncingGameEmptyiOS onboard missing samples 2019-08-01 19:56:58 -07:00
ButtonEventDemo
ButtonTapper3000
Calendars
Chat
CircleLayout
CollectionViewTransition
Contacts
Controls
CoreAnimation
CoreImage
CoreLocation
CoreMidiSample
CoreTelephonyDemo
CreatingTabbedApplications
CustomCollectionViewLayoutAttributes
CustomInputStream onboard missing samples 2019-08-01 19:45:18 -07:00
CustomPropertyAnimation onboard missing samples 2019-08-01 19:45:18 -07:00
CustomTransitions
Data
DesignerWalkthrough
DispatchSourceExamples
Drawing
DynamicsCatalog
FileSystemSampleCode Remove invalid project from FileSystemSampleCode (#404) 2020-08-12 17:24:44 -04:00
FontList
FrogScroller
GLCameraRipple update readmes, fix links 2019-07-23 12:04:22 -07:00
GLPaint-GameView
GameCenterSample
GoogleAdMobAds/binding
GraphicsAndAnimation
GrowRowTable
HelloWorld_iPhone onboard missing samples 2019-08-01 20:25:15 -07:00
Hello_ComplexUniversal
Hello_MultiScreen_iPhone
Hello_Universal
Hello_iOS
Hello_iPad
HomeKit/HomeKitIntro
HttpClient
ImageProtocol
InfColorPicker
IntroToiOS7
IntroductionToiCloud
KeyValueObserving
Keychain
LazyTableImages de-duplicate csproj GUIDs (#379) 2019-08-16 14:23:29 -07:00
LazyTableImagesAsync
LifecycleDemo
LineLayout onboard missing samples 2019-08-01 22:09:15 -07:00
LocalNotifications
Location
LowLevelGLPaint
MTDJsonDemo
MTDReflectionWalkthrough
MTDWalkthrough
MTGKTapper
ManualCameraControls onboard missing samples 2019-08-01 22:09:15 -07:00
ManualStoryboard
MapCallouts
MapDemo
MapKitSearch
MapsWalkthrough
MediaNotes
MidiTest
MonoCatalog-MonoDevelop
MonoDevelopTouchCells
MotionGraphs
MoviePlayback update readme, fix links 2019-07-23 13:26:12 -07:00
MultichannelMixer
NSZombieApocalypse
NavigationBar
Newsstand
Notifications
OpenGL
OpenGLESSample
OpenGLESSample_GameView update readme, fix links 2019-07-23 13:26:12 -07:00
OpenGLScroller update readme, fix links 2019-07-23 13:26:12 -07:00
PaintCode update readme, fix links 2019-07-23 13:26:12 -07:00
PassKit
PeekPopNavigation
PickerControl
PinchIt
PokerNightVoting
Popovers
PrintBanner
PrintSample
PrivacyPrompts
Profiling/MemoryDemo [MemoryDemo] Make sure the same output path isn't used with multiple configurations. (#395) 2019-12-02 22:38:49 +01:00
Protocols_Delegates_Events
QRchestra
QuartzSample
Quotes onboard missing samples 2019-08-01 22:24:39 -07:00
Reachability
RecipesAndPrinting onboard missing samples 2019-08-01 22:24:39 -07:00
RegionDefiner
RosyWriter
Rotation
ScratchTicket
SearchDemo onboard missing samples 2019-08-01 22:24:39 -07:00
SharedResources
SimpleBackgroundFetch
SimpleBackgroundTransfer fix spacing 2020-10-28 14:40:29 -05:00
SimpleCollectionView
SimpleDrillDown
SimpleLogin
SimpleTextInput
SoZoomy
SocialFrameworkDemo
Sound
SplitView
SpriteKit
SpriteKitPhysicsCollisions
SpriteTour
Stars
StateRestoration
StoreKit
StoryboardIntro
StoryboardTable
StoryboardTable_LocalAuthentication de-duplicate csproj GUIDs (#379) 2019-08-16 14:23:29 -07:00
StreamingAudio
SystemSound
TabbedImages
TableEditing
TableParts
TableSwipeActions
TextKitDemo update header yaml 2019-07-29 19:48:37 -07:00
ThreadedCoreData
TicTacToe
Touch
TouchesClassic onboard mssing samples 2019-08-01 22:35:19 -07:00
Touches_GestureRecognizers de-duplicate csproj GUIDs (#379) 2019-08-16 14:23:29 -07:00
TransitionsDemo
UICatalog
UIImageEffects
ViewTransitions
WalkingGameCompleteiOS
WalkingGameEmptyiOS onboard missing samples 2019-08-02 09:09:43 -07:00
WatchKit
WayUpSample
WeatherMap onboard missing samples 2019-08-02 09:09:43 -07:00
WebView
WorkingWithImages onboard missing samples 2019-08-02 09:09:43 -07:00
WorkingWithTables
Working_with_images
WorldCities
ZoomingPdfViewer
iOS7-ui-updates
intro-to-extensions
ios7fonts
ios8
ios9
ios10 remove hashtags ios9 ios10 watchos 2019-07-24 17:48:58 -07:00
ios11
ios12
ios13 Fix ColorFeed sample by adding required Info.plist keys (#393) 2020-04-06 19:20:17 -05:00
tvos
watchOS remove hashtags ios9 ios10 watchos 2019-07-24 17:48:58 -07:00
.gitattributes
.gitignore
LICENSE
Makefile
README.md
Xamarin.Edu.SampleGallery.Core.dll
install-hook.sh
mdtool-build
pre-commit.posix
validate.posix Fix usage of `find` in some scripts. 2012-02-17 21:39:36 +01:00
xcsv.exe

README.md

iOS/tvOS/watchOS Samples

The samples in this directory use the Xamarin.iOS toolchain and Xamarin project files to illustrate the basics of how to work with iOS and the SDK. Visit the iOS Sample Gallery to download individual samples.

License

See the repo's license file and any additional license information attached to each sample.

Samples Layout

Version Specific Samples

Starting with iOS 8, we started adding samples that showcase specific features introduced in a release into a directory for the release. So all the new iOS 8 feature samples live in the ios8 directory, the iOS 9 features live in the ios9 directory and the iOS 10 feature lives in the ios10 directory, and so on for ios11, ios12, ios13...

watchOS

watchOS samples are in the watchOS directory, including:

NOTE: The WatchKit samples are deprecated, please refer to these samples in the watchOS directory.

tvOS

tvOS samples are in the tvos directory, including the tvOS UI Catalog.

Contributing

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.

Samples Submission Guidelines

Galleries

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:

Sample GitHub Repositories

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.

Sample Requirements

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 ios11/MapKitSample.

  • Readme - a README.md file that explains the sample, and contains metadata to help customers find it. For an example of this, see ios11/MapKitSample. The README file should begin with a YAML header (delimited by ---) with the following keys/values:

    • name - must begin with Xamarin.iOS -

      • 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, objc

      • 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 ios11/MapKitSample README raw view.

      ---
      name: Xamarin.iOS - MapKit Sample
      description: "Demo of new iOS 11 features in MapKit, grouping and splitting markers based on zoom-level. Tandm is a fictional bike sharing... (iOS11)"
      page_type: sample
      languages:
      - csharp
      products:
      - xamarin
      urlFragment: ios11-mapkitsample
      ---
      # 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 iOS 11 maps sample: https://github.com/xamarin/ios-samples/tree/master/ios11/MapKitSample

For a cross-platform sample, please see: https://github.com/xamarin/mobile-samples/tree/master/Tasky

GitHub Integration

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 on Xamarin Forums!