2017-11-06 16 views

答えて

1

エントリは、スクロールをサポートしていないiOSのUITextFieldとしてレンダリングされます。エディタは、スクロールをサポートするUITextViewとしてレンダリングされます。

1つのオプションは、プレースホルダを含むカスタムエディタを作成することです。

これにはコードがあります。それはかなりではありませんが、それは動作します。

ここには、プレースホルダのテキストと色の新しいバインド可能なプロパティを含むCustomEditorコードがあります。ここで

public class CustomEditor : Editor 
    { 
     public static readonly BindableProperty PlaceholderProperty = 
      BindableProperty.Create(nameof(Placeholder), typeof(string), typeof(CustomEditor), default(string)); 

     public string Placeholder 
     { 
      get { return (string)GetValue(PlaceholderProperty); } 
      set { SetValue(PlaceholderProperty, value); } 
     } 

     public static readonly BindableProperty PlaceholderColorProperty = 
      BindableProperty.Create(nameof(PlaceholderColor), typeof(Color), typeof(CustomEditor), default(Color)); 

     public Color PlaceholderColor 
     { 
      get { return (Color)GetValue(PlaceholderColorProperty); } 
      set { SetValue(PlaceholderColorProperty, value); } 
     } 

     public static readonly BindableProperty DisabledColorProperty = 
      BindableProperty.Create(nameof(DisabledColor), typeof(Color), typeof(CustomEditor), default(Color)); 

     public Color DisabledColor 
     { 
      get { return (Color)GetValue(DisabledColorProperty); } 
      set { SetValue(DisabledColorProperty, value); } 
     } 
    } 

は、iOSのカスタムレンダラ

[assembly: ExportRenderer(typeof(CustomEditor), typeof(CustomEditorRenderer))] 
namespace Test.iOS.CustomRenderers 
{ 
    public class CustomEditorRenderer : EditorRenderer 
    { 
     private UILabel PlaceholderLabel { get; set; } 

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

      if (Control == null) return; 

      Control.Layer.BorderWidth = 0.5f; 
      Control.Layer.CornerRadius = 8; 
      Control.Layer.BorderColor = Color.FromHex("CDCDCD").ToCGColor(); 

      if (PlaceholderLabel != null) return; 

      var element = Element as CustomEditor; 

      PlaceholderLabel = new UILabel 
      { 
       Text = element?.Placeholder, 
       TextColor = element?.PlaceholderColor.ToUIColor(), 
       BackgroundColor = UIColor.Clear 
      }; 

      var edgeInsets = Control.TextContainerInset; 
      var lineFragmentPadding = Control.TextContainer.LineFragmentPadding; 

      Control.AddSubview(PlaceholderLabel); 

      var vConstraints = NSLayoutConstraint.FromVisualFormat(
       "V:|-" + edgeInsets.Top + "-[PlaceholderLabel]-" + edgeInsets.Bottom + "-|", 0, new NSDictionary(), 
       NSDictionary.FromObjectsAndKeys(
        new NSObject[] { PlaceholderLabel }, new NSObject[] { new NSString("PlaceholderLabel") }) 
      ); 

      var hConstraints = NSLayoutConstraint.FromVisualFormat(
       "H:|-" + lineFragmentPadding + "-[PlaceholderLabel]-" + lineFragmentPadding + "-|", 
       0, new NSDictionary(), 
       NSDictionary.FromObjectsAndKeys(
        new NSObject[] { PlaceholderLabel }, new NSObject[] { new NSString("PlaceholderLabel") }) 
      ); 

      PlaceholderLabel.TranslatesAutoresizingMaskIntoConstraints = false; 

      Control.AddConstraints(hConstraints); 
      Control.AddConstraints(vConstraints); 

      PlaceholderLabel.Hidden = Element.Text.NotEmpty(); 
     } 

     protected override void OnElementPropertyChanged(object sender, System.ComponentModel.PropertyChangedEventArgs e) 
     { 
      base.OnElementPropertyChanged(sender, e); 

      if (e.PropertyName == "Text") 
      { 
       PlaceholderLabel.Hidden = Control.Text.NotEmpty(); 
      } 

      if (e.PropertyName == VisualElement.IsEnabledProperty.PropertyName) 
      { 
       var element = Element as CustomEditor; 
       SetTextColor(element); 
      } 
     } 

     private void SetTextColor(CustomEditor element) 
     { 
      Control.TextColor = element.IsEnabled ? element.TextColor.ToUIColor() : element.DisabledColor.ToUIColor(); 
     } 
    } 
} 
ある
関連する問題