Search code examples
c#xamlxamarin.formsbinding

How to add binding property to Label with converter BoolToObjectConverter


I've the next converter code like the example in this post Xamarin.Forms Binding Converter but when the value come in method only have the property Path="DeviceHasScanner" and the Binding property never is called :(

public class BoolToObjectConverter<T> : IValueConverter
    {
       public T TrueObject { set; get; }

       public T FalseObject { set; get; }

       public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
       {
           return (bool)value ? TrueObject : FalseObject;
       }

       public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
       {
           return ((T)value).Equals(TrueObject);
       }
   }

And I'm try implement it on this way:

<Image HorizontalOptions="Center" WidthRequest="200">
     <Image.Source>
         <Binding Source="{Binding DeviceHasScanner}">
               <Binding.Converter>
                     <converters:BoolToObjectConverter x:TypeArguments="x:String"  TrueObject="presstoscan.png" FalseObject="scanwithcamera.png" />
                </Binding.Converter>
          </Binding>
     </Image.Source>
 </Image>

And the boolean binding property in viewmodel is:

public bool DeviceHasScanner
    {
        get 
        {
            return Settings.Get.DeviceHasScanner; //This code return true or false
        }
    }

What is the correct way to implement it? BoolToObjectConverter class


Solution

  • This is not something that you should be using a converter for tbh, what you should be doing instead is assigning your ImageSource through a boolean or keeping the condition for this in your VM where this is directly handled. Converters are usually used in scenarios where you have value conversions.

    But if you still insist on using this approach then there are some basic changes that you will need to do first of all you are misunderstanding what Source means here,

    <Binding Source="{Binding DeviceHasScanner}">
    

    Source in the above code does not mean the property which you need to provide but the context in which you wanna perform the lookup, that is the reason when you see the object it just copy-pastes the name you have as binding here, Now Source is only required if your Converter should be looking up in a particular context. I am pretty sure this is not the case here so all you need to do is give the Path property the value of your Binding.

    So this <Binding Source="{Binding DeviceHasScanner}"> would become something like

    <Binding Path="DeviceHasScanner"/>
    

    Now here if your Source is in the same Binding Context you won't need to do anything but if it's not then you need to provide the reference of your BindingContext as shown in the example you can find https://learn.microsoft.com/en-us/xamarin/xamarin-forms/app-fundamentals/data-binding/converters#binding-converter-properties

    Good luck!!