'How to align image to the left and text to the center on a Xamarin button in iOS?
I want to align my text in the center, but the image on the left. I have tried it with HorizontalAlignment, but it aligns both. How to do it?
Solution 1:[1]
I took the time to actually understand how "insets" work, and wrote my own solution.
[assembly: ExportRenderer(typeof(Button), typeof(RingotanButtonRenderer))]
namespace MyAppNamespace
{
    public class MyButtonRenderer : ButtonRenderer
    {
        public override void LayoutSubviews()
        {
            base.LayoutSubviews();
            // Left-align the image and center the text
            // Taken from https://stackoverflow.com/a/71044012/238419
            if (Element.ContentLayout.Position == Button.ButtonContentLayout.ImagePosition.Left)
            {
                const int imageMargin = 20; // This might need to get multiplied by the screen density, not sure yet.  I'll update this later if it does.
                nfloat imageOffset = Control.ImageView.Frame.Left - imageMargin;
                Control.ImageEdgeInsets = new UIEdgeInsets(0, -imageOffset, 0, imageOffset);
                nfloat imageWidth = Control.ImageView.Frame.Width + imageMargin;
                nfloat textOffset = Control.TitleLabel.Frame.Left - (imageWidth + Control.Frame.Width - Control.TitleLabel.Frame.Width) / 2;
                Control.TitleEdgeInsets = new UIEdgeInsets(0, -textOffset, 0, textOffset);
            }
        }
    }
}
Notes:
- If you want the text to be centered on the overall button, rather than centered on the available remaining space, set 
imageWidth = 0 - If you only want this to apply to some buttons, create a new class that extends 
Buttonand set theExportRendererto that new class. Then only use that new class where you want the text centered. - This only works for left-aligned images, but similar math can be used for the other alignments
 - There seems to be a bug where Xamarin/iOS ignores the inset if you return to a page containing the button by hitting the 'back' button on the navigation menu. I haven't been able to find a workaround to this bug yet.
 
Solution 2:[2]
Try to use ButtonContentLayout.ImagePosition property:
Solution 3:[3]
do you know how I could set it from Control in ButtonRenderer?
You can change the ImageEdgeInsets and TitleEdgeInsets of the button in the renderer to change the image and title position:
[assembly: ExportRenderer (typeof(Button), typeof(MyButtonRenderer))]
namespace App650.iOS
{
    public class MyButtonRenderer : ButtonRenderer
    {
        protected override void OnElementChanged(ElementChangedEventArgs<Button> e)
        {
            base.OnElementChanged(e);
            if (e.NewElement != null)
            {
                //Control is UIButton
                Control.ImageEdgeInsets = new UIEdgeInsets(0, Control.Frame.Size.Width - (Control.ImageView.Frame.Size.Width), 0, 0);
                Control.TitleEdgeInsets = new UIEdgeInsets(0, 0, 0, Control.ImageView.Frame.Size.Width);
            }
        }
    }
}
    					Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source | 
|---|---|
| Solution 1 | |
| Solution 2 | Alexey Strakh | 
| Solution 3 | 

