From 5c8a0363d5f1174ec7b3601d7a683e3a22326816 Mon Sep 17 00:00:00 2001 From: Axemasta <33064621+Axemasta@users.noreply.github.com> Date: Wed, 3 Apr 2024 09:37:49 +0100 Subject: [PATCH] Update Migration Guide Based On MCT Changes We're now setting the binding context automatically on the TouchBehavior so I've updated the docs to reflect the current state of the feature --- docs/maui/behaviors/touch-behavior.md | 93 ++++++++------------------- 1 file changed, 27 insertions(+), 66 deletions(-) diff --git a/docs/maui/behaviors/touch-behavior.md b/docs/maui/behaviors/touch-behavior.md index 006b27bf..ad62ca43 100644 --- a/docs/maui/behaviors/touch-behavior.md +++ b/docs/maui/behaviors/touch-behavior.md @@ -273,16 +273,36 @@ You can find the source code for `TouchBehavior` over on the [.NET MAUI Communit ## Migrating From Xamarin Community Toolkit -In the [Xamarin Community Toolkit](https://github.com/xamarin/XamarinCommunityToolkit), there was the [`TouchEffect`](/dotnet/api/xamarin.communitytoolkit.effects.toucheffect?view=xamarin-community-toolkit-sdk) if you are upgrading an app from Xamarin.Forms to .NET Maui there are a number of changes that you need to be aware of: - -1. [`TouchBehavior` is now a `PlatformBehavior`](#TouchBehavior-is-now-a-PlatformBehavior) -2. [The `BindingContext` is not automatically set](#Setting-The-TouchBehavior-Binding-Context) - -### TouchBehavior is now a PlatformBehavior +In the [Xamarin Community Toolkit](https://github.com/xamarin/XamarinCommunityToolkit), there was the [`TouchEffect`](/dotnet/api/xamarin.communitytoolkit.effects.toucheffect?view=xamarin-community-toolkit-sdk) if you are upgrading an app from Xamarin.Forms to .NET Maui there are some breaking changes that you should be aware of: + +1. [API Name Changes](#API-Name-Changes) +2. [TouchBehavior is now implemented as a `PlatformBehavior`](#TouchBehavior-is-now-implemented-as-a-`PlatformBehavior`) + +### API Name Changes + +| Name In Xamarin Community Toolkit | Name In Maui Community Toolkit | +|-----------------------------------|------------------------------------------------------| +| TouchEffect | TouchBehavior | +| NormalBackgroundColor | DefaultBackgroundColor | +| NormalScale | DefaultScale | +| NormalOpacity | DefaultOpacity | +| NormalTranslationX | DefaultTranslationX | +| NormalTranslationY | DefaultTranslationY | +| NormalRotation | DefaultRotation | +| NormalRotationX | DefaultRotationX | +| NormalRotationY | DefaultRotationY | +| NormalAnimationDuration | DefaultAnimationDuration | +| NormalAnimationEasing | DefaultAnimationEasing | +| NormalBackgroundImageSource | DefaultImageSource (Moved to `ImageTouchBehavior`) | +| NormalBackgroundImageAspect | DefaultImageAspect (Moved to `ImageTouchBehavior` ) | + +### TouchBehavior is now implemented as a `PlatformBehavior` In the Xamarin Community Toolkit the `TouchEffect` was implemented as an `AttachedEffect`. To use the effect you would use the attached properties and apply to any `VisualElement` -In .NET Maui the `TouchBehavior` is implemented as a `PlatformBehavior` behavior is now applied to the elements behavior collection, see [Platform Behaviors](/dotnet/maui/fundamentals/behaviors#platform-behaviors) for more information. +In .NET Maui the `TouchBehavior` is implemented as a `PlatformBehavior` which is now applied to the elements behavior collection, see [Platform Behaviors](/dotnet/maui/fundamentals/behaviors#platform-behaviors) for more information. + +> Note: By default in .NET Maui `PlatformBehavior`s will not set a BindingContext, this is because Behaviors can be shared in styles. The `TouchBehavior` will set it's `BindingContext` equal to the `VisualElement` it is applied to. This means that you should not share the `TouchBehavior` between elements via styles. Below is an example of a `TouchEffect` being applied to a view in Xamarin Forms: @@ -325,63 +345,4 @@ The equivalent `TouchBehavior` in .NET Maui would look like this: HeightRequest="100" WidthRequest="10" /> -``` - -### Setting The TouchBehavior Binding Context - -As noted in the previous section, the `BindingContext` of the behavior is not set automatically, the reason for this is outlined in the Maui documentation for [Behaviors](/dotnet/maui/fundamentals/behaviors#create-a-net-maui-behavior): - -> .NET MAUI does not set the BindingContext of a behavior, because behaviors can be shared and applied to multiple controls through styles. - -You should note that whilst .NET Maui behaviors can be shared via styles, the `TouchBehavior` is inteded to be applied to a specific `VisualElement` and should not be shared across multiple views. A new instance of the `TouchBehavior` should be created for every `VisualElement` it is applied to. - -Since the `TouchBehavior` does not inherit any `BindingContext`, the use of [Relative bindings](/dotnet/maui/fundamentals/data-binding/relative-bindings) is unsupported since the behavior has no way of obtaining any information about the `BindingContext` of the `VisualElement` it is applied to. Instead you should use an element in your view as an anchor to provide the `BindingContext` for the `TouchBehavior` using an `x:Reference`. - -You can set an `x:Name` on any element on page to set the `BindingContext` of the `TouchBehavior` to your respective viewmodel. A convenient way of doing this is setting this at the root element of your view, for example the `ContentPage`. - -```xaml - - - - - - - - - -``` - -If you are using a templated view, such as a `DataTemplate` you should use the parent view instead: - -```xaml - - - - - - - - - - - - ``` \ No newline at end of file