Introduction
This article demonstrates how to create and use a custom switch control in Xamarin.Forms using XAML and C#. This article starts with the introduction of the CustomSwitch tag in XAML. After that, it demonstrates how to set BorderColor, ThumbColor, and ThumbImage of a Custom Switch.
![Xamarin]()
Implementation
Open Visual Studio and create a "New Project".
 ![Xamarin]()
Another way to create a project is to go to File >> New>>Project or press ctrl+Shft+N.
![Xamarin]()
Now, select Cross-Platform App, give the project a name, and set the project path. Then, click OK.
![Xamarin]()
Select the template as "Blank App" and code sharing as "PCL".
![Xamarin]()
Right-click on PCL Project and select Add >> New Item or Add >> Class.
![Xamarin]()
Now, we give the class a name as "CustomSwich.cs".
![Xamarin]()
 
Now, generate the custom properties...
![Xamarin]()
CustomSwitch.cs
- public class CustomSwitch : Switch  
-    {  
-        public static readonly BindableProperty SwitchOffColorProperty =  
-          BindableProperty.Create(nameof(SwitchOffColor),  
-              typeof(Color), typeof(CustomSwitch),  
-              Color.Default);  
-   
-        public Color SwitchOffColor  
-        {  
-            get { return (Color)GetValue(SwitchOffColorProperty); }  
-            set { SetValue(SwitchOffColorProperty, value); }  
-        }  
-   
-        public static readonly BindableProperty SwitchOnColorProperty =  
-          BindableProperty.Create(nameof(SwitchOnColor),  
-              typeof(Color), typeof(CustomSwitch),  
-              Color.Default);  
-   
-        public Color SwitchOnColor  
-        {  
-            get { return (Color)GetValue(SwitchOnColorProperty); }  
-            set { SetValue(SwitchOnColorProperty, value); }  
-        }  
-   
-        public static readonly BindableProperty SwitchThumbColorProperty =  
-          BindableProperty.Create(nameof(SwitchThumbColor),  
-              typeof(Color), typeof(CustomSwitch),  
-              Color.Default);  
-   
-        public Color SwitchThumbColor  
-        {  
-            get { return (Color)GetValue(SwitchThumbColorProperty); }  
-            set { SetValue(SwitchThumbColorProperty, value); }  
-        }  
-   
-        public static readonly BindableProperty SwitchThumbImageProperty =  
-          BindableProperty.Create(nameof(SwitchThumbImage),  
-              typeof(string),  
-              typeof(CustomSwitch),  
-              string.Empty);  
-   
-        public string SwitchThumbImage  
-        {  
-            get { return (string)GetValue(SwitchThumbImageProperty); }  
-            set { SetValue(SwitchThumbImageProperty, value); }  
-        }  
-    }  
This property is set in the Android project as well as in iOS project.
Let us start with Android. We are creating a Class in Android Project and rendering the Switch. Then, we set all the properties when we generate it in PCL Project.
![Xamarin]()
Please make sure of the dependency [assembly: ExportRenderer(typeof(CustomSwitch), typeof(MySwitchRenderer))] of Android (MySwitchRndered) and PCL (CustomSwitch).
![Xamarin]()
MySwitchRenderer.cs
- public class MySwitchRendererd : SwitchRenderer  
-     {  
-         private CustomSwitch view;  
-         protected override void OnElementChanged(ElementChangedEventArgs<Xamarin.Forms.Switch> e)  
-         {  
-             base.OnElementChanged(e);  
-             if (e.OldElement != null || e.NewElement == null)  
-                 return;  
-             view = (CustomSwitch)Element;  
-             if (Android.OS.Build.VERSION.SdkInt >= Android.OS.BuildVersionCodes.JellyBean)  
-             {  
-                 if (this.Control != null)  
-                 {  
-                     if (this.Control.Checked)  
-                     {  
-                         this.Control.TrackDrawable.SetColorFilter(view.SwitchOnColor.ToAndroid(), PorterDuff.Mode.SrcAtop);  
-                     }  
-                     else  
-                     {  
-                         this.Control.TrackDrawable.SetColorFilter(view.SwitchOffColor.ToAndroid(), PorterDuff.Mode.SrcAtop);  
-                     }  
-                    this.Control.CheckedChange += this.OnCheckedChange;  
-                     UpdateSwitchThumbImage(view);  
-                 }  
-                   
-             }  
-         }  
-           
-         private void UpdateSwitchThumbImage(CustomSwitch view)  
-         {  
-             if (!string.IsNullOrEmpty(view.SwitchThumbImage))  
-             {  
-                 view.SwitchThumbImage = view.SwitchThumbImage.Replace(".jpg", "").Replace(".png", "");  
-                 int imgid = (int)typeof(Resource.Drawable).GetField(view.SwitchThumbImage).GetValue(null);  
-                 Control.SetThumbResource(Resource.Drawable.icon);  
-             }  
-             else  
-             {  
-                 Control.ThumbDrawable.SetColorFilter(view.SwitchThumbColor.ToAndroid(), PorterDuff.Mode.Multiply);  
-                   
-             }  
-         }  
-   
-       private void OnCheckedChange(object sender, CompoundButton.CheckedChangeEventArgs e)  
-         {  
-             if (this.Control.Checked)  
-             {  
-                 this.Control.TrackDrawable.SetColorFilter(view.SwitchOnColor.ToAndroid(), PorterDuff.Mode.SrcAtop);  
-             }  
-             else  
-             {  
-                 this.Control.TrackDrawable.SetColorFilter(view.SwitchOffColor.ToAndroid(), PorterDuff.Mode.SrcAtop);  
-             }  
-         }  
-         protected override void Dispose(bool disposing)  
-         {  
-             this.Control.CheckedChange -= this.OnCheckedChange;  
-             base.Dispose(disposing);  
-         }  
-     }  
Now, it's time to go to the iOS project and set the PCL (CustomSwitch) properties in iOS Project….
We are creating a Class, so right click on iOS project and select Apple. Then, select "Class" and give this class a name as MySliderRendered.cs.
![Xamarin]()
Now, let us write some code for Switch and Set Properties.
![Xamarin]()
MySwitchRenderer.cs
- public class MySwitchRendererd : SwitchRenderer  
-     {  
-         Version version = new Version(ObjCRuntime.Constants.Version);  
-         protected override void OnElementChanged(ElementChangedEventArgs<Switch> e)  
-         {  
-             base.OnElementChanged(e);  
-             if (e.OldElement != null || e.NewElement == null)  
-                 return;  
-             var view = (CustomSwitch)Element;  
-             if (!string.IsNullOrEmpty(view.SwitchThumbImage))  
-             {  
-                 if (version > new Version(6, 0))  
-                 {     
-                     Control.OnImage = UIImage.FromFile(view.SwitchThumbImage.ToString());  
-                       
-                     Control.OffImage = UIImage.FromFile(view.SwitchThumbImage.ToString());  
-                 }  
-                 else  
-                 {  
-                     Control.ThumbTintColor = view.SwitchThumbColor.ToUIColor();  
-                 }  
-             }  
-               
-             Control.ThumbTintColor = view.SwitchThumbColor.ToUIColor();  
-               
-               
-             Control.OnTintColor = view.SwitchOnColor.ToUIColor();  
-               
-             Control.TintColor = view.SwitchOffColor.ToUIColor();  
-         }  
-     }  
Now, go to the PCL project and use in the MainPage.xaml.
![Xamarin]()
As you can see in the above code, we have to set the view reference in xmlns:custom="clr-namespace:XamarinControlApp.CustomControls" MainPage.xaml.
Write the following code for CustomSwitch.
MainPage.xaml
- <ContentPage.Content>  
-         <StackLayout Padding="20" BackgroundColor="Gray" >  
-             <Label Text="Custom Switch" FontSize="Large"/>  
-            <cs:CustomSwitch x:Name="customSwitch"  
-                                 SwitchOffColor="Yellow"  
-                                  SwitchOnColor="Black"  
-                                  SwitchThumbImage="icon"  
-                                  HorizontalOptions="CenterAndExpand"  
-                                  VerticalOptions="CenterAndExpand"/>  
-                 <cs:CustomSwitch SwitchOffColor="Navy"  
-                                  SwitchOnColor="Green"  
-                                  SwitchThumbColor="Violet"  
-                                  HorizontalOptions="CenterAndExpand"  
-                                  VerticalOptions="CenterAndExpand"/>  
-         </StackLayout>  
-     </ContentPage.Content>  
 
![Xamarin]()
Now, you will have your CustomSwitch working!!
NOTE
Not tested on iOS.
Features of CustomSwitch Controls
- Custom Switch On Color Property=(SwitchOnColor="Red")
- Custom Switch Off Color Property=(SwitchOffColor="Yellow")
- Custom Switch Thumb Color Property=(SwitchThumbColor="Yellow")
- Custom Thumb Image Property=(SwitchThumbImage="Black")