你好,试试这个代码来改变 iOS 入口看起来像原生 Android 入口
在你的 ios 部分添加这个渲染器;焦点和非焦点颜色也在变化。
记住这一行来添加上面的命名空间
[程序集:ExportRenderer(typeof(Entry), typeof(CustomEntryRenderer))]
public class CustomEntryRenderer : EntryRenderer
{
private CALayer _borderLayer;
protected override void OnElementChanged(ElementChangedEventArgs<Entry> e)
{
base.OnElementChanged(e);
if (Control == null)
return;
Control.BorderStyle = UITextBorderStyle.None;
var element = Element as Entry;
if (element == null)
return;
//DrawBorder(element.BorderColor.ToCGColor());
DrawBorder(UIColor.FromRGB(156, 156, 156));
e.NewElement.Unfocused += (sender, evt) =>
{
DrawBorder(UIColor.FromRGB(156, 156, 156)); // unfocused, set color
};
e.NewElement.Focused += (sender, evt) =>
{
DrawBorder(UIColor.FromRGB(245, 0, 47)); ; // focused, set color
};
}
protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e)
{
base.OnElementPropertyChanged(sender, e);
var element = Element as Entry;
if (element == null)
return;
DrawBorder(UIColor.FromRGB(156, 156, 156));
}
public override CGRect Frame
{
get { return base.Frame; }
set
{
base.Frame = value;
var element = Element as Entry;
if (element == null)
return;
// DrawBorder(element.BorderColor.ToCGColor());
DrawBorder(UIColor.FromRGB(156, 156, 156));
}
}
private void DrawBorder(UIColor borderColor)
{
if (Frame.Height <= 0 || Frame.Width <= 0)
return;
if (_borderLayer == null)
{
_borderLayer = new CALayer
{
MasksToBounds = true,
Frame = new CGRect(0f, Frame.Height - 1, Frame.Width, 1f),
BorderColor = borderColor.CGColor,
BorderWidth = 1.0f
};
Control.Layer.AddSublayer(_borderLayer);
Control.BorderStyle = UITextBorderStyle.None;
}
else
{
_borderLayer.BorderColor = borderColor.CGColor;
_borderLayer.Frame = new CGRect(0f, Frame.Height - 1, Frame.Width, 1f);
}
}
}