Родитель
fc7d556848
Коммит
faa6eae8e7
|
@ -72,8 +72,7 @@ public class FormsViewGroup extends ViewGroup {
|
|||
float rotation,
|
||||
float rotationX,
|
||||
float rotationY,
|
||||
float scaleX,
|
||||
float scaleY
|
||||
float scale,
|
||||
float translationX,
|
||||
float translationY){
|
||||
setPivotX (pivotX);
|
||||
|
@ -89,8 +88,8 @@ public class FormsViewGroup extends ViewGroup {
|
|||
setRotation (rotation);
|
||||
setRotationX (rotationX);
|
||||
setRotationY (rotationY);
|
||||
setScaleX (scaleX);
|
||||
setScaleY (sclaeY);
|
||||
setScaleX (scale);
|
||||
setScaleY (scale);
|
||||
setTranslationX (translationX);
|
||||
setTranslationY (translationY);
|
||||
}
|
||||
|
|
|
@ -39,41 +39,19 @@ namespace Xamarin.Forms.Controls
|
|||
scaleSlider.SetBinding(Slider.ValueProperty,
|
||||
new Binding("Scale", BindingMode.TwoWay));
|
||||
|
||||
// Label and Slider for ScaleX property.
|
||||
Label scaleXSliderValue = new Label {
|
||||
VerticalTextAlignment = TextAlignment.Center
|
||||
};
|
||||
Grid.SetRow(scaleXSliderValue, 1);
|
||||
Grid.SetColumn(scaleXSliderValue, 0);
|
||||
|
||||
Slider scaleXSlider = new Slider {
|
||||
Maximum = 10
|
||||
};
|
||||
Grid.SetRow(scaleXSlider, 1);
|
||||
Grid.SetColumn(scaleXSlider, 1);
|
||||
|
||||
// Set Bindings.
|
||||
scaleXSliderValue.BindingContext = scaleXSlider;
|
||||
scaleXSliderValue.SetBinding(Label.TextProperty,
|
||||
new Binding("Value", BindingMode.OneWay, null, null, "ScaleX = {0:F1}"));
|
||||
|
||||
scaleXSlider.BindingContext = label;
|
||||
scaleXSlider.SetBinding(Slider.ValueProperty,
|
||||
new Binding("ScaleX", BindingMode.TwoWay));
|
||||
|
||||
// Label and Slider for Rotation property.
|
||||
Label rotationSliderValue = new Label
|
||||
{
|
||||
VerticalTextAlignment = TextAlignment.Center
|
||||
};
|
||||
Grid.SetRow(rotationSliderValue, 2);
|
||||
Grid.SetRow(rotationSliderValue, 1);
|
||||
Grid.SetColumn(rotationSliderValue, 0);
|
||||
|
||||
Slider rotationSlider = new Slider
|
||||
{
|
||||
Maximum = 360
|
||||
};
|
||||
Grid.SetRow(rotationSlider, 2);
|
||||
Grid.SetRow(rotationSlider, 1);
|
||||
Grid.SetColumn(rotationSlider, 1);
|
||||
|
||||
// Set Bindings.
|
||||
|
@ -90,7 +68,7 @@ namespace Xamarin.Forms.Controls
|
|||
{
|
||||
VerticalTextAlignment = TextAlignment.Center
|
||||
};
|
||||
Grid.SetRow(anchorxStepperValue, 3);
|
||||
Grid.SetRow(anchorxStepperValue, 2);
|
||||
Grid.SetColumn(anchorxStepperValue, 0);
|
||||
|
||||
Stepper anchorxStepper = new Stepper
|
||||
|
@ -99,7 +77,7 @@ namespace Xamarin.Forms.Controls
|
|||
Minimum = -1,
|
||||
Increment = 0.5
|
||||
};
|
||||
Grid.SetRow(anchorxStepper, 3);
|
||||
Grid.SetRow(anchorxStepper, 2);
|
||||
Grid.SetColumn(anchorxStepper, 1);
|
||||
|
||||
// Set bindings.
|
||||
|
@ -116,7 +94,7 @@ namespace Xamarin.Forms.Controls
|
|||
{
|
||||
VerticalTextAlignment = TextAlignment.Center
|
||||
};
|
||||
Grid.SetRow(anchoryStepperValue, 4);
|
||||
Grid.SetRow(anchoryStepperValue, 3);
|
||||
Grid.SetColumn(anchoryStepperValue, 0);
|
||||
|
||||
Stepper anchoryStepper = new Stepper
|
||||
|
@ -125,7 +103,7 @@ namespace Xamarin.Forms.Controls
|
|||
Minimum = -1,
|
||||
Increment = 0.5
|
||||
};
|
||||
Grid.SetRow(anchoryStepper, 4);
|
||||
Grid.SetRow(anchoryStepper, 3);
|
||||
Grid.SetColumn(anchoryStepper, 1);
|
||||
|
||||
// Set bindings.
|
||||
|
@ -152,7 +130,6 @@ namespace Xamarin.Forms.Controls
|
|||
new RowDefinition { Height = GridLength.Auto },
|
||||
new RowDefinition { Height = GridLength.Auto },
|
||||
new RowDefinition { Height = GridLength.Auto },
|
||||
new RowDefinition { Height = GridLength.Auto },
|
||||
},
|
||||
ColumnDefinitions =
|
||||
{
|
||||
|
@ -163,8 +140,6 @@ namespace Xamarin.Forms.Controls
|
|||
{
|
||||
scaleSliderValue,
|
||||
scaleSlider,
|
||||
scaleXSliderValue,
|
||||
scaleXSlider,
|
||||
rotationSliderValue,
|
||||
rotationSlider,
|
||||
anchorxStepperValue,
|
||||
|
|
|
@ -48,10 +48,6 @@ namespace Xamarin.Forms
|
|||
|
||||
public static readonly BindableProperty ScaleProperty = BindableProperty.Create("Scale", typeof(double), typeof(VisualElement), 1d);
|
||||
|
||||
public static readonly BindableProperty ScaleXProperty = BindableProperty.Create("ScaleX", typeof(double), typeof(VisualElement), 1d);
|
||||
|
||||
public static readonly BindableProperty ScaleYProperty = BindableProperty.Create("ScaleY", typeof(double), typeof(VisualElement), 1d);
|
||||
|
||||
public static readonly BindableProperty IsVisibleProperty = BindableProperty.Create("IsVisible", typeof(bool), typeof(VisualElement), true,
|
||||
propertyChanged: (bindable, oldvalue, newvalue) => ((VisualElement)bindable).OnIsVisibleChanged((bool)oldvalue, (bool)newvalue));
|
||||
|
||||
|
@ -246,16 +242,6 @@ namespace Xamarin.Forms
|
|||
set { SetValue(ScaleProperty, value); }
|
||||
}
|
||||
|
||||
public double ScaleX {
|
||||
get { return (double)GetValue(ScaleXProperty); }
|
||||
set { SetValue(ScaleXProperty, value); }
|
||||
}
|
||||
|
||||
public double ScaleY {
|
||||
get { return (double)GetValue(ScaleYProperty); }
|
||||
set { SetValue(ScaleYProperty, value); }
|
||||
}
|
||||
|
||||
public Style Style
|
||||
{
|
||||
get { return (Style)GetValue(StyleProperty); }
|
||||
|
|
|
@ -120,7 +120,7 @@ namespace Xamarin.Forms.Platform.Android
|
|||
if (e.PropertyName == VisualElement.XProperty.PropertyName || e.PropertyName == VisualElement.YProperty.PropertyName || e.PropertyName == VisualElement.WidthProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.HeightProperty.PropertyName)
|
||||
_layoutNeeded = true;
|
||||
else if (e.PropertyName == VisualElement.AnchorXProperty.PropertyName || e.PropertyName == VisualElement.AnchorYProperty.PropertyName || e.PropertyName == VisualElement.ScaleProperty.PropertyName || e.PropertyName == VisualElement.ScaleXProperty.PropertyName || e.PropertyName == VisualElement.ScaleYProperty.PropertyName ||
|
||||
else if (e.PropertyName == VisualElement.AnchorXProperty.PropertyName || e.PropertyName == VisualElement.AnchorYProperty.PropertyName || e.PropertyName == VisualElement.ScaleProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.RotationProperty.PropertyName || e.PropertyName == VisualElement.RotationXProperty.PropertyName || e.PropertyName == VisualElement.RotationYProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.IsVisibleProperty.PropertyName || e.PropertyName == VisualElement.OpacityProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.TranslationXProperty.PropertyName || e.PropertyName == VisualElement.TranslationYProperty.PropertyName)
|
||||
|
@ -138,7 +138,7 @@ namespace Xamarin.Forms.Platform.Android
|
|||
UpdateAnchorX();
|
||||
else if (e.PropertyName == VisualElement.AnchorYProperty.PropertyName)
|
||||
UpdateAnchorY();
|
||||
else if (e.PropertyName == VisualElement.ScaleProperty.PropertyName || e.PropertyName == VisualElement.ScaleXProperty.PropertyName || e.PropertyName == VisualElement.ScaleYProperty.PropertyName)
|
||||
else if (e.PropertyName == VisualElement.ScaleProperty.PropertyName)
|
||||
UpdateScale();
|
||||
else if (e.PropertyName == VisualElement.RotationProperty.PropertyName)
|
||||
UpdateRotation();
|
||||
|
@ -230,7 +230,7 @@ namespace Xamarin.Forms.Platform.Android
|
|||
UpdateRotationX();
|
||||
if (oldElement.RotationY != newElement.RotationY)
|
||||
UpdateRotationY();
|
||||
if (oldElement.Scale != newElement.Scale || oldElement.ScaleX != newElement.ScaleY || oldElement.ScaleY != newElement.ScaleY)
|
||||
if (oldElement.Scale != newElement.Scale)
|
||||
UpdateScale();
|
||||
// ReSharper restore CompareOfFloatsByEqualityOperator
|
||||
|
||||
|
@ -299,18 +299,9 @@ namespace Xamarin.Forms.Platform.Android
|
|||
if (aview is FormsViewGroup)
|
||||
{
|
||||
var formsViewGroup = (FormsViewGroup)aview;
|
||||
formsViewGroup.SendBatchUpdate((float)(view.AnchorX * _context.ToPixels(view.Width)),
|
||||
(float)(view.AnchorY * _context.ToPixels(view.Height)),
|
||||
(int)(view.IsVisible ? ViewStates.Visible : ViewStates.Invisible),
|
||||
view.IsEnabled,
|
||||
(float)view.Opacity,
|
||||
(float)view.Rotation,
|
||||
(float)view.RotationX,
|
||||
(float)view.RotationY,
|
||||
(float)view.ScaleX,
|
||||
(float)view.ScaleY,
|
||||
_context.ToPixels(view.TranslationX),
|
||||
_context.ToPixels(view.TranslationY));
|
||||
formsViewGroup.SendBatchUpdate((float)(view.AnchorX * _context.ToPixels(view.Width)), (float)(view.AnchorY * _context.ToPixels(view.Height)),
|
||||
(int)(view.IsVisible ? ViewStates.Visible : ViewStates.Invisible), view.IsEnabled, (float)view.Opacity, (float)view.Rotation, (float)view.RotationX, (float)view.RotationY, (float)view.Scale,
|
||||
_context.ToPixels(view.TranslationX), _context.ToPixels(view.TranslationY));
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -374,8 +365,8 @@ namespace Xamarin.Forms.Platform.Android
|
|||
VisualElement view = _renderer.Element;
|
||||
AView aview = _renderer.ViewGroup;
|
||||
|
||||
aview.ScaleX = (float)view.Scale * (float)view.ScaleX;
|
||||
aview.ScaleY = (float)view.Scale * (float)view.ScaleY;
|
||||
aview.ScaleX = (float)view.Scale;
|
||||
aview.ScaleY = (float)view.Scale;
|
||||
}
|
||||
|
||||
void UpdateTranslationX()
|
||||
|
|
|
@ -160,7 +160,7 @@ namespace Xamarin.Forms.Platform.WinPhone
|
|||
MaybeInvalidate();
|
||||
else if (e.PropertyName == VisualElement.AnchorXProperty.PropertyName || e.PropertyName == VisualElement.AnchorYProperty.PropertyName)
|
||||
UpdateScaleAndRotation(Model, Element);
|
||||
else if (e.PropertyName == VisualElement.ScaleProperty.PropertyName || e.PropertyName == VisualElement.ScaleXProperty.PropertyName || e.PropertyName == VisualElement.ScaleYProperty.PropertyName )
|
||||
else if (e.PropertyName == VisualElement.ScaleProperty.PropertyName)
|
||||
UpdateScaleAndRotation(Model, Element);
|
||||
else if (e.PropertyName == VisualElement.TranslationXProperty.PropertyName || e.PropertyName == VisualElement.TranslationYProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.RotationProperty.PropertyName || e.PropertyName == VisualElement.RotationXProperty.PropertyName || e.PropertyName == VisualElement.RotationYProperty.PropertyName)
|
||||
|
@ -350,8 +350,9 @@ namespace Xamarin.Forms.Platform.WinPhone
|
|||
{
|
||||
double anchorX = view.AnchorX;
|
||||
double anchorY = view.AnchorY;
|
||||
double scale = view.Scale;
|
||||
frameworkElement.RenderTransformOrigin = new System.Windows.Point(anchorX, anchorY);
|
||||
frameworkElement.RenderTransform = new ScaleTransform { ScaleX = view.Scale * view.ScaleX, ScaleY = view.Scale * view.ScaleY };
|
||||
frameworkElement.RenderTransform = new ScaleTransform { ScaleX = scale, ScaleY = scale };
|
||||
|
||||
UpdateRotation(view, frameworkElement);
|
||||
}
|
||||
|
|
|
@ -188,7 +188,7 @@ namespace Xamarin.Forms.Platform.WinRT
|
|||
{
|
||||
UpdateScaleAndRotation(Element, Container);
|
||||
}
|
||||
else if (e.PropertyName == VisualElement.ScaleProperty.PropertyName || e.PropertyName == VisualElement.ScaleXProperty.PropertyName ||)e.PropertyName == VisualElement.ScaleYProperty.PropertyName
|
||||
else if (e.PropertyName == VisualElement.ScaleProperty.PropertyName)
|
||||
{
|
||||
UpdateScaleAndRotation(Element, Container);
|
||||
}
|
||||
|
@ -470,8 +470,9 @@ namespace Xamarin.Forms.Platform.WinRT
|
|||
{
|
||||
double anchorX = view.AnchorX;
|
||||
double anchorY = view.AnchorY;
|
||||
double scale = view.Scale;
|
||||
frameworkElement.RenderTransformOrigin = new Windows.Foundation.Point(anchorX, anchorY);
|
||||
frameworkElement.RenderTransform = new ScaleTransform { ScaleX = view.Scale * view.ScaleX, view.Scale * view.ScaleY = scale };
|
||||
frameworkElement.RenderTransform = new ScaleTransform { ScaleX = scale, ScaleY = scale };
|
||||
|
||||
UpdateRotation(view, frameworkElement);
|
||||
}
|
||||
|
|
|
@ -78,7 +78,7 @@ namespace Xamarin.Forms.Platform.MacOS
|
|||
{
|
||||
if (e.PropertyName == VisualElement.XProperty.PropertyName || e.PropertyName == VisualElement.YProperty.PropertyName || e.PropertyName == VisualElement.WidthProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.HeightProperty.PropertyName || e.PropertyName == VisualElement.AnchorXProperty.PropertyName || e.PropertyName == VisualElement.AnchorYProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.TranslationXProperty.PropertyName || e.PropertyName == VisualElement.TranslationYProperty.PropertyName || e.PropertyName == VisualElement.ScaleProperty.PropertyName || e.PropertyName == VisualElement.ScaleXProperty.PropertyName || e.PropertyName == VisualElement.ScaleYProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.TranslationXProperty.PropertyName || e.PropertyName == VisualElement.TranslationYProperty.PropertyName || e.PropertyName == VisualElement.ScaleProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.RotationProperty.PropertyName || e.PropertyName == VisualElement.RotationXProperty.PropertyName || e.PropertyName == VisualElement.RotationYProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.IsVisibleProperty.PropertyName || e.PropertyName == VisualElement.IsEnabledProperty.PropertyName ||
|
||||
e.PropertyName == VisualElement.InputTransparentProperty.PropertyName || e.PropertyName == VisualElement.OpacityProperty.PropertyName)
|
||||
|
@ -135,8 +135,6 @@ namespace Xamarin.Forms.Platform.MacOS
|
|||
var rotationY = (float)view.RotationY;
|
||||
var rotation = (float)view.Rotation;
|
||||
var scale = (float)view.Scale;
|
||||
var scaleX = (float)view.ScaleX * scale;
|
||||
var scaleY = (float)view.ScaleY * scale;
|
||||
var width = (float)view.Width;
|
||||
var height = (float)view.Height;
|
||||
var x = (float)view.X;
|
||||
|
@ -229,8 +227,8 @@ namespace Xamarin.Forms.Platform.MacOS
|
|||
if (Math.Abs(translationX) > epsilon || Math.Abs(translationY) > epsilon)
|
||||
transform = transform.Translate(translationX, translationY, 0);
|
||||
|
||||
if (Math.Abs(scaleX - 1) > epsilon || Math.Abs(scaleY - 1) > epsilon)
|
||||
transform = transform.Scale(scaleX, scaleY, scale);
|
||||
if (Math.Abs(scale - 1) > epsilon)
|
||||
transform = transform.Scale(scale);
|
||||
|
||||
// not just an optimization, iOS will not "pixel align" a view which has m34 set
|
||||
if (Math.Abs(rotationY % 180) > epsilon || Math.Abs(rotationX % 180) > epsilon)
|
||||
|
|
Загрузка…
Ссылка в новой задаче