【问题标题】:How to create gradient button background in xamarin forms for iOS如何在 iOS 的 xamarin 表单中创建渐变按钮背景
【发布时间】:2015-11-24 11:53:20
【问题描述】:

我正在 Xamarin 表单中创建一个需要渐变按钮背景的 iPhone 应用程序。我试过CAGradientLayer。但是,它不适用于按钮。

谁能帮我解决这个问题? 这是我的按钮渲染器:

    protected override void OnElementChanged (ElementChangedEventArgs<Button> e)
    {
        base.OnElementChanged (e);

        if(e.OldElement == null)
        {

            btn = (UIButton) Control;
            btn.Frame = new RectangleF (0, 0, (float)this.Element.WidthRequest, (float)this.Element.HeightRequest);
            CAGradientLayer btnGradient = new CAGradientLayer ();
            btnGradient.Frame = btn.Bounds;
            btnGradient.Colors = new CGColor[]{ Color.White.ToCGColor(), Color.FromHex("#0073BD").ToCGColor() };
            btn.Layer.InsertSublayer (btnGradient, 0);
            btn.Layer.MasksToBounds = true;
            btn.Layer.BorderColor = Color.FromHex("#0073BE").ToCGColor();
            btn.Layer.BorderWidth = 1;
            btn.SetTitleColor(Color.Black.ToUIColor (), UIControlState.Normal);
        }
    }

【问题讨论】:

  • 你能发布你的自定义渲染器吗?

标签: ios uibutton xamarin.forms cagradientlayer


【解决方案1】:

我建议只在前面制作渐变图像并直接使用它们,除非您需要在运行时动态创建渐变。如果您走图像路线,那么您将执行以下操作:

var regImg = UIImage.FromBundle("myimage.png").ImageWithRenderingMode(UIImageRenderingMode.AlwaysOriginal);
var selImg = UIImage.FromBundle("myimage_selected.png").ImageWithRenderingMode(UIImageRenderingMode.AlwaysOriginal);

Control.SetBackgroundImage(regImg, UIControlState.Normal);
Control.SetBackgroundImage(selImg, UIControlState.Highlighted);

如果您仍想使用动态创建的渐变路线,请查看这篇文章 - 您会看到他正在通过他创建的 ImageWithColor() 方法动态创建他的图像:

https://forums.xamarin.com/discussion/32240/set-buttontype-in-buttonrenderer-ios-specific

最后,请确保您将按钮的 ImageType 设置为自定义 - 我没有看到您在渲染器中进行设置,并且默认情况下 iOS 会在 iOS7 之后绘制无边框按钮。

【讨论】:

    猜你喜欢
    • 2011-03-13
    • 1970-01-01
    • 1970-01-01
    • 2012-08-26
    • 1970-01-01
    • 1970-01-01
    • 2011-01-24
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多