Tests and prototypes using Xamarin.Forms Composite Controls and ControlTemplate
Перейти к файлу
Javier Suárez Ruiz f7415b2a10 Updated README 2019-11-17 19:39:56 +01:00
images
src Updated MainPage 2019-11-17 19:35:28 +01:00
.gitattributes
.gitignore
Memory Performance.xlsx
README.md Updated README 2019-11-17 19:39:56 +01:00
Startup Performance.xlsx

README.md

Xamarin.Forms Composite Controls

In this repository there are only some tests related to the idea of composite controls, have a Template property and be able to use ControlTemplate to customize a control.

Composite Controls

Let's see more details!

For these tests we have created a Slider Composite control (composed of other Views that make up the control).

Composite Control

We have the same visual appearance, properties and events. However, the control has a Template property that allows us to modify the ControlTemplate that defines the control.

We modify the Slider ControlTemplate:

<ControlTemplate x:Key="CustomSliderTemplate">
    <Grid 
        VerticalOptions="Center"
        Margin="10, 0">
        <BoxView 
            x:Name="MaximumTrack"
            BackgroundColor="Green"
            Margin="6,0"
            CornerRadius="6"
            HeightRequest="6"
            Opacity="0.24"
            VerticalOptions="Center" />
        <BoxView 
            x:Name="MinimumTrack"
            BackgroundColor="Green"
            Margin="6,0"
            CornerRadius="6"
            HeightRequest="6"
            HorizontalOptions="Start"
            InputTransparent="True"
            VerticalOptions="Center"
            WidthRequest="0" />
        <Image        
            x:Name="Thumb" 
            Margin="0"
            BackgroundColor="Transparent"
            Source="football.png"
            HeightRequest="36"
            HorizontalOptions="Start"
            VerticalOptions="Center"
            WidthRequest="36" />
    </Grid>
</ControlTemplate>

And we use it:

<Slider 
    Template="{StaticResource CustomSliderTemplate}"/>

The result:

ControlTemplate

We can use XAML Hot Reload to adjust the appearance:

Using XAML Hot Reload

Some performance related data (using Android):

Memory

  • 127545344 (121MB) - Slider
  • 127246336 (121MB) - Slider (Composite)

Startup time (Release AOT)

  • 797ms - Slider
  • 801ms - Slider (Composite)

Feedback

You can create feedback in this repository. If you have any questions, please don't hesitate to create an issue.