-
-
Notifications
You must be signed in to change notification settings - Fork 2.3k
Breaking Changes
Breaking changes are sometimes unavoidable. We are trying to deprecate API before removing it, but it's not always possible due to either high performance impact of the old design or due to major changes in the corresponding subsystem. The list of API areas where changes are planned and most likely unavoidable can be found here.
For more breaking changes in 11.0 release visit pull request list.
Avalonia.Animation
, Avalonia.Input
, Avalonia.Interactivity
, Avalonia.Layout
, Avalonia.Visuals
and Avalonia.Styling
assemblies were merged into a Avalonia.Base
assembly. While API surface wasn't changed, it's still a binary breaking change, and third-party packages needs to be recompiled to work with a new version.
Both Avalonia.Themes.Fluent
and Avalonia.Themes.Default
are not a part of the main Avalonia
nuget package anymore. You need to add a PackageReference to include either of these packages or both. For more details, see #5593
Methods like OnPropertyChanged do not have generic parameter anymore. See #7980.
In additon, generic methods were removed from IAvaloniaObject
, so if you have an instance of this interface or one of its derived interfaces (e.g. IControl
) then you should cast to a concrete type in order to access the typed GetValue<T>
, SetValue<T>
etc. methods or use the extension methods in the Avalonia namespace.
Avalonia.ReactiveUI.Events
will no longer be supported. Use Pharmacist.MSBuild instead. How to use it? For more details, see #5423
PointerEntered and PointerExited events were renamed to match UWP/WinUI naming. See #8396.
NumericUpDown.Value is now a decimal property. See #5981.
ManagedFileDialog is now a templated control. See #4615.
-
If your readonly property fields are declared as of type
AvaloniaProperty<T>
then you should change them toStyledProperty<>
orDirectProperty<,>
fields -
The signature for
OnPropertyChanged
has changed and is now a generic method in order to avoid allocation and boxing. To cast theoldValue
andnewValue
parameters to a concrete type, use.ValueOrDefault<T>()
onOptional<T>
andBindingValue<T>
-
Avalonia properties now take a separate validation and coercion callback the same as WPF. The validation callback cannot be overridden, though the coercion callback can.
-
The
PropertyMetadata
class has now been renamed toAvaloniaPropertyMetadata
.
-
Interactive.AddHandler
no longer returns anIDisposable
. If you want a disposable you should callAddDisposableHandler
: https://github.com/AvaloniaUI/Avalonia/pull/3651
- Many
AvaloniaObject.Bind()
overloads have been moved to be extension methods, so you may have to addthis.
to yourBind()
call when binding to this
The static PseudoClass
method was removed: https://github.com/AvaloniaUI/Avalonia/pull/3292
The recommended way to implement pseudoclasses is now like this https://github.com/AvaloniaUI/Avalonia/pull/3292/files#diff-45a4dd48c9a2f83d7def2fd422d1423c
- Removed opacity parameter from
DrawingContext.DrawImage
- instead usePushOpacity
before drawing the image
-
FontSize
is no longer part ofTypeFace
- it can now be found onFormattedText
-
FormattedText.Wrapping
is now calledTextWrapping
Avalonia.Diagnostics
is now a separate NuGet package so if you're using AttachDevTools
you'll have to add a reference to that.
OnTemplatedApplied
has been renamed to on OnApplyTemplate
.
DatePicker
was renamed to CalendarDatePicker
. A DatePicker
control has been added.
The LogToDebug
method has moved from the Avalonia.Logging.Serilog
namesapce to the Avalonia
namespace. Remove using Avalonia.Logging.Serilog;
to fix.
The preferred way of managing app startup and lifetime is now using lifetimes. You still can use AppMain approach introduced in 0.8 for more fine-grained control, but some of Application.Run/AppBuilder.Start overloads were removed or deprecated.
- x:Class is now mandatory for XAML files with codebehind (windows, user controls,
App.cs
, etc) - Class constructors and codebehind event handlers must be public
-
<Style>
without selector is no longer valid - Style selectors without type information (e. g.
<Style Selector=".myclass">
) are no longer valid, specify the target type using eitherControl.myclass
or:is(Control).myclass
Controls are no longer automagically registered in some random name scope that they find in the visual tree. Instead name scopes are now managed manually. If you are using XAML you probably won't notice any breaking changes since our XAML engine manages name registrations automatically, but just setting Name
from code will no longer work, you'd have to actually register your controls and pass INameScope
instance to bindings.
ItemsControl.MemberSelector
has been removed. Instead use a DataTemplate
with a binding to the property to be displayed.
The Orientation
enum was moved to the Avalonia.Layout namespace.
Has been renamed to VisualLayerManager
.
Both BeginResizeDrag
and BeginMoveDrag
now has an additional PointerPressedEventArg
parameter.
DropDown
has been renamed to ComboBox
. A shim for DropDown
is still available for now but deprecated and will be removed in a future release.
FormattedText.Measure
has become FormattedText.Bounds
.
See https://github.com/AvaloniaUI/Avalonia/pull/2344
The following members now use PixelPosition
/PixelRect
:
IWindowBaseImpl.Position
IWindowBaseImpl.PositionChanged
ITopLevelImpl.PointToClient
ITopLevelImpl.PointToScreen
IMouseDevice.Position
Screen.Bounds
Screen.WorkingArea
You can use one of the From*
static methods and To*
instance methods on these structs with a scaling factor to convert between Position
and Rect
.
See https://github.com/AvaloniaUI/Avalonia/pull/2250
The StringConverter
methods have been renamed to add an Is
prefix:
-
StringConverters.NullOrEmpty
becomesStringConverters.IsNullOrEmpty
-
StringConverters.NotNullOrEmpty
becomesStringConverters.IsNotNullOrEmpty
See https://github.com/AvaloniaUI/Avalonia/pull/2253
The TreeContainerIndex.Items
property have been renamed to Containers
.
See https://github.com/AvaloniaUI/Avalonia/pull/2356
Before:
public static AppBuilder BuildAvaloniaApp()
{
var builder = AppBuilder.Configure<App>();
if(RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
builder.UseX11(new X11PlatformOptions() {UseGpu = false});
else if(RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
builder.UseAvaloniaNative(anopts =>
{
anopts.UseGpu = false;
anopts.MacOptions.ShowInDock = 0;
});
else if(RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
builder.UseWin32(false, true);
return builder;
}
After:
public static AppBuilder BuildAvaloniaApp() => AppBuilder.Configure<App>()
.UsePlatformDetect()
.With(new X11PlatformOptions { UseGpu = false })
.With(new AvaloniaNativePlatformOptions { UseGpu = false })
.With(new MacOSPlatformOptions { ShowInDock = false })
.With(new Win32PlatformOptions { UseDeferredRendering = false });
See https://github.com/AvaloniaUI/Avalonia/pull/2368
- Projects that use ReactiveUI framework will need to migrate to Reactive UI 9.0.1 which Avalonia now uses.
- Existing
TemplateBindings
which specifyPath=
will stop working, as thePath
property was removed and replaced withProperty
. Simply remove thePath=
qualifier or change it toProperty=
if the path was a simple property - Existing
TemplateBindings
which don't bind to a simple property on the templated parent will need to be changed to regularBinding
s withRelativeSourceMode.TemplatedParent
See https://github.com/AvaloniaUI/Avalonia/pull/1695
- The Gap property has been renamed to Spacing to be consistent with UWP and other XAML frameworks.
See https://github.com/AvaloniaUI/Avalonia/pull/1786
- BugFix: For the replace operation in the
SelectedItems
collection,AddedItems
andRemovedItems
members of theSelectionChangedEventArgs
class had their contents switched.
See https://github.com/AvaloniaUI/Avalonia/pull/1913
Was moved to Application.Windows
: https://github.com/AvaloniaUI/Avalonia/pull/1662
- The
DataValidatiorBase
base class has been renamed toDataValidationBase
.
See https://github.com/AvaloniaUI/Avalonia/pull/1858
- The
AndroidKeyboardEventsHelper<TView>.ActivateAutoShowKeybord
method has been renamed toAndroidKeyboardEventsHelper<TView>.ActivateAutoShowKeyboard
.
See https://github.com/AvaloniaUI/Avalonia/pull/1859
- The
KeyboardEventsHelper<TView>.ActivateAutoShowKeybord
method has been renamed toKeyboardEventsHelper<TView>.ActivateAutoShowKeyboard
.
See https://github.com/AvaloniaUI/Avalonia/pull/1859
- The
UseGtk3
method parameters changed toGtk3PlatformOptions
.
See https://github.com/AvaloniaUI/Avalonia/pull/1935
We have removed Avalonia.MonoMac
, please use Avalonia.Native
instead.
https://github.com/AvaloniaUI/Avalonia/pull/1992/files
We have removed Avalonia.DotNetCoreRuntime
, please use Avalonia.DesktopRuntime
instead.
- Renamed theme resource from
ThemeBorderLightColor
toThemeBorderLowColor
. - Renamed theme resource from
ThemeControlLightColor
toThemeControlLowColor
. - Renamed theme resource from
ThemeForegroundLightColor
toThemeForegroundLowColor
. - Renamed theme resource from
ErrorLightColor
toErrorLowColor
. - Renamed theme resource from
ThemeBorderLightBrush
toThemeBorderLowBrush
. - Renamed theme resource from
ThemeControlLightBrush
toThemeControlLowBrush
. - Renamed theme resource from
ThemeForegroundLightBrush
toThemeForegroundLowBrush
. - Renamed theme resource from
ErrorLightBrush
toErrorLowBrush
. - Renamed theme resource from
ThemeBorderDarkColor
toThemeBorderHighColor
. - Renamed theme resource from
ThemeControlDarkColor
toThemeControlHighColor
. - Renamed theme resource from
ThemeControlHighlightDarkColor
toThemeControlHighlightHighColor
. - Renamed theme resource from
ThemeBorderDarkBrush
toThemeBorderHighBrush
. - Renamed theme resource from
ThemeControlDarkBrush
toThemeControlHighBrush
. - Renamed theme resource from
ThemeControlHighlightDarkBrush
toThemeControlHighlightHighBrush
.
See https://github.com/AvaloniaUI/Avalonia/pull/2023
Changed both PixelHeight
and PixelWidth
into a PixelSize
struct.
The constructor now requires the size to be provided using PixelSize and also a DPI. Use 96 as a default.
See https://github.com/AvaloniaUI/Avalonia/pull/1889
You now need BuildAvaloniaApp
static method in the class with your entry point (typically in Program.cs
or App.xaml.cs
) which should be called from Main
:
static void Main(string[] args)
{
BuildAvaloniaApp().Start<MainWindow>();
}
public static AppBuilder BuildAvaloniaApp()
=> AppBuilder.Configure<App>()
.UsePlatformDetect()
.LogToDebug();
Previewer won't be able to work without it.
They were replaced by OnDataContextBeginUpdate
and OnDataContextEndUpdate
They were replaced by standard x:Static
and x:Type
, add xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
to the root of your XAML file.
StyleResource
has been replaced by StaticResource
and DynamicResource
as in other XAML frameworks. StaticResource
and DynamicResource
in Avalonia search both Control.Resources
and Style.Resources
.
MouseDevice
is no longer available from the global context, you need to obtain one from TopLevel
(Window
, Popup
, etc). Call GetVisualRoot()
in your control and cast it to IInputRoot
.
var pos = (_control.GetVisualRoot() as IInputRoot)?.MouseDevice?.Position ?? default(Point);