The latest trend for loading approaches in Xamarin Forms apps. Skeleton can be easily implemented on each view contained in your Xaml.
- Available on NuGet: Xamarin.Forms.Skeleton
- Install into your Core and Client projects.
Platform Support
Platform | Version |
---|---|
Xamarin.iOS | iOS 8+ |
Xamarin.Android | API 16+ |
Xamarin.Forms | >= 4.0.0.425677 |
You must add this namespace to your xaml files:
xmlns:extension="clr-namespace:Xamarin.Forms.Skeleton;assembly=Xamarin.Forms.Skeleton"
Add the following properties to generate a loading animation:
<ListView RowHeight="109"
SeparatorVisibility="None"
SelectionMode="None"
VerticalOptions="FillAndExpand"
ItemTemplate="{StaticResource ItemTemplate}"
ItemsSource="{Binding Items}"
extension:Skeleton.IsParent="True"
extension:Skeleton.IsBusy="{Binding IsBusy}"
extension:Skeleton.Animation="Fade" />
Add the following properties to set a loading animation with a specific background color:
<Label Text="{Binding Title}"
TextColor="#c92726"
FontSize="Large"
extension:Skeleton.IsBusy="{Binding IsBusy}"
extension:Skeleton.BackgroundColor="#c6c6c5" />
- Indicates if it is a parent control which has skeleton children controls.
- The default value is false.
- Indicates if the control is busy in a loading state.
- The default value is false.
- Control background color when is busy.
- The default value is the xamarin forms default color.
- Indicates if the control is hide when is busy.
- The default value is false.
- Control animation when is busy.
- Possible values: None, Fade and Beat (working in new Animations for the next release)
- The default value is None.
- Animation interval when is busy.
- Value in milliseconds.
- The default value is 500.
- Animation parameter to modify the animation.
- The default value is null.
https://github.com/HorusSoftwareUY/Xamarin.Forms.Skeleton/tree/master/SkeletonExample
- New animations
- Automatic ItemsSource population (fake data) for skeleton preview in: ListView, CollectionView, Repeater, etc.
Contributions are welcome! If you find a bug want a feature added please report it.
If you want to contribute code please file an issue, create a branch, and file a pull request.
MIT License - see LICENSE.txt