In MvvmCross how do I do custom bind properties

10,121

There's an example of adding a custom 2-way binding for "IsFavorite" in the Conference sample - see:

This example is explained a bit further in: MVVMCross Bindings in Android

For a one-way "source-to-target" custom binding, the code should be a bit simpler - you only need to handle the SetValue - and don't need to invoke FireValueChanged in any event handling code.


For textColor, I'd imagine the binding would look a bit like:

public class MyCustomBinding
    : MvxBaseAndroidTargetBinding
{
    private readonly TextView _textView;

    public MyCustomBinding(TextView textView)
    {
        _textView = textView;
    }

    public override void SetValue(object value)
    {
        var colorValue = (Color)value;
        _textView.SetTextColor(colorValue);
    }

    public override Type TargetType
    {
        get { return typeof(Color); }
    }

    public override MvxBindingMode DefaultMode
    {
        get { return MvxBindingMode.OneWay; }
    }
}

and would be setup with:

    protected override void FillTargetFactories(MvvmCross.Binding.Interfaces.Bindings.Target.Construction.IMvxTargetBindingFactoryRegistry registry)
    {
        base.FillTargetFactories(registry);

        registry.RegisterFactory(new MvxCustomBindingFactory<TextView>("TextColor", (textView) => new MyCustomBinding(textView)));
    }

Note: I've not compiled this example code - when you do get it working, please come back and correct this pseudo-code :)

Share:
10,121
Jason Steele
Author by

Jason Steele

Updated on June 16, 2022

Comments

  • Jason Steele
    Jason Steele almost 2 years

    I am using MvxBindableListView to bind a List<> of data objects to a ListView. The layout I am using for the rows has several TextViews. I am successfully binding the Text property for each of these to a property in my data object, but I have found that I cannot bind to TextColor as that property does not exist in Mono For Android TextViews; instead you have use the SetTextColor() method. So how can I bind a data object property to a method?! Below is the code I tried to use:

        <TextView
            android:id="@+id/MyValueTextView"
            android:layout_width="50dp"
            android:layout_height="20dp"
            android:layout_gravity="right"
            android:gravity="center_vertical|right"
            android:textSize="12sp"
            local:MvxBind="
            {
              'Text':{'Path':'MyValue','Converter':'MyValueConverter'},
              'TextColor':{'Path':'MyOtherValue','Converter':'MyOtherConverter'}
            }" />