Xamarin表单:如何在按钮中添加填充?

sga*_*dev 20 mono xaml xamarin.ios xamarin xamarin.forms

我有以下XAML Xamarin.Forms.Button

<Button Text="Cancel" BackgroundColor="#3079a8" TextColor="White" />
Run Code Online (Sandbox Code Playgroud)

我试图通过Padding属性为它添加填充,但这不起作用.在检查了论坛和文档之后,我意识到Xamarin.Forms.Button (链接到文档)的文档中没有填充属性 ,是否还有一些其他类型的快速修复可以为按钮添加更多的填充?一个代码示例将不胜感激.

Dbl*_*Dbl 44

用法:

<controls:EnhancedButton Padding="1,2,3,4"/>
Run Code Online (Sandbox Code Playgroud)

好处:

  • 没有讨厌的副作用
  • 对齐没问题
  • 没有viewtree丑陋
  • 没有视图深度增量

IOS:

[assembly: ExportRenderer(typeof(EnhancedButton), typeof(EnhancedButtonRenderer))]
namespace YOURNAMESPACE.iOS
{
    public class EnhancedButtonRenderer : ButtonRenderer
    {
        protected override void OnElementChanged(ElementChangedEventArgs<Button> e)
        {
            base.OnElementChanged(e);
            UpdatePadding();
        }

        private void UpdatePadding()
        {
            var element = this.Element as EnhancedButton;
            if (element != null)
            {
                this.Control.ContentEdgeInsets = new UIEdgeInsets(

                    (int)element.Padding.Top,
                    (int)element.Padding.Left,
                    (int)element.Padding.Bottom,
                    (int)element.Padding.Right
                );
            }
        }

        protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e)
        {
            base.OnElementPropertyChanged(sender, e);
            if (e.PropertyName == nameof(EnhancedButton.Padding))
            {
                UpdatePadding();
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

机器人:

[assembly: ExportRenderer(typeof(EnhancedButton), typeof(EnhancedButtonRenderer))]
namespace YOURNAMESPACE.Droid
{
    public class EnhancedButtonRenderer : ButtonRenderer
    {
        protected override void OnElementChanged(ElementChangedEventArgs<Button> e)
        {
            base.OnElementChanged(e);
            UpdatePadding();
        }

        private void UpdatePadding()
        {
            var element = this.Element as EnhancedButton;
            if (element != null)
            {
                this.Control.SetPadding(
                    (int)element.Padding.Left,
                    (int)element.Padding.Top,
                    (int)element.Padding.Right, 
                    (int)element.Padding.Bottom
                );
            }
        }

        protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e)
        {
            base.OnElementPropertyChanged(sender, e);
            if (e.PropertyName == nameof(EnhancedButton.Padding))
            {
                UpdatePadding();
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

PCL:

public class EnhancedButton : Button
{
    #region Padding    

    public static BindableProperty PaddingProperty = BindableProperty.Create(nameof(Padding), typeof(Thickness), typeof(EnhancedButton), default(Thickness), defaultBindingMode:BindingMode.OneWay);

    public Thickness Padding
    {
        get { return (Thickness) GetValue(PaddingProperty); }
        set { SetValue(PaddingProperty, value); }
    }

    #endregion Padding
}
Run Code Online (Sandbox Code Playgroud)

解决方案使用效果而不是渲染器,以便轻松使用多个控件:

XAML:

<Label Text="Welcome to Xamarin.Forms!" BackgroundColor="Red">
    <Label.Effects>
        <xamTest:PaddingEffect Padding="20,40,20,40"></xamTest:PaddingEffect>
    </Label.Effects>
</Label>
Run Code Online (Sandbox Code Playgroud)

PCL:

[assembly: ResolutionGroupName("ComponentName")]
namespace XamTest
{
    public class PaddingEffect : RoutingEffect
    {
        /// <inheritdoc />
        protected PaddingEffect(string effectId) : base($"ComponentName.{nameof(PaddingEffect)}")
        {
        }

        public Thickness Padding { get; set; }
    }
}
Run Code Online (Sandbox Code Playgroud)

安卓:

[assembly: ResolutionGroupName("ComponentName")]
[assembly: ExportEffect(typeof(XamTest.Droid.PaddingEffect), "PaddingEffect")]
namespace XamTest.Droid
{
    public class PaddingEffect : PlatformEffect
    {
        /// <inheritdoc />
        protected override void OnAttached()
        {
            if (this.Control != null)
            {
                var firstMatch = this.Element.Effects.FirstOrDefault(d => d is XamTest.PaddingEffect);
                if (firstMatch is XamTest.PaddingEffect effect)
                {
                    this.Control.SetPadding((int)effect.Padding.Left, (int)effect.Padding.Top, (int)effect.Padding.Right, (int)effect.Padding.Bottom);
                }
            }
        }

        /// <inheritdoc />
        protected override void OnDetached()
        {
        }
    }
}
Run Code Online (Sandbox Code Playgroud)


Ada*_*ley 12

更新:

填充已添加到Xamarin.Forms v3.2 +中的XF Button控件

<Button Padding="10,20,10,20" />
Run Code Online (Sandbox Code Playgroud)

旧:

最好的方法是增加按钮的大小.

然后根据需要对齐文本.不幸的是,这是你能做的最好的事情.如果您的文本中心对齐,它可以很好地工作.如果它的左或右对齐,那就不那么多了.


Ido*_*doT 5

你可以在你的包裹按钮StackLayout并添加填充到StackLayout

 <StackLayout Padding="10,10,10,10">
     <Button Text="Cancel" BackgroundColor="#3079a8" TextColor="White" />
  </StackLayout>
Run Code Online (Sandbox Code Playgroud)

  • 这可能是必需的,但在按钮周围添加填充将使其成为一个余量. (10认同)