From 17fdde66d94155fc62a034fa6658995bef6fd6e5 Mon Sep 17 00:00:00 2001 From: Jason Smith Date: Tue, 22 Mar 2016 13:02:25 -0700 Subject: Initial import --- .../ViewContainers/LayeredViewContainer.cs | 38 ++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 Xamarin.Forms.Controls/ViewContainers/LayeredViewContainer.cs (limited to 'Xamarin.Forms.Controls/ViewContainers/LayeredViewContainer.cs') diff --git a/Xamarin.Forms.Controls/ViewContainers/LayeredViewContainer.cs b/Xamarin.Forms.Controls/ViewContainers/LayeredViewContainer.cs new file mode 100644 index 00000000..e22ecfb6 --- /dev/null +++ b/Xamarin.Forms.Controls/ViewContainers/LayeredViewContainer.cs @@ -0,0 +1,38 @@ +using System; + +namespace Xamarin.Forms.Controls +{ + internal class LayeredViewContainer : ViewContainer + where T : View + { + public LayeredViewContainer (Enum formsMember, T view) : base (formsMember, view) + { + var layout = new AbsoluteLayout (); + + var hiddenButton = new Button { + AutomationId = formsMember + "LayeredHiddenButton", + Text = "Covered Up" + }; + + layout.Children.Add (hiddenButton); + AbsoluteLayout.SetLayoutFlags (hiddenButton, AbsoluteLayoutFlags.All); + AbsoluteLayout.SetLayoutBounds (hiddenButton, new Rectangle (0, 0, 1, 1)); + layout.Children.Add (view); + AbsoluteLayout.SetLayoutBounds (view, new Rectangle (0, 0, 1, 1)); + AbsoluteLayout.SetLayoutFlags (view, AbsoluteLayoutFlags.All); + + var hiddenLabel = new Label { + AutomationId = formsMember + "LayeredLabel", + Text = "Hidden Button (Not Clicked)" + }; + + hiddenButton.Clicked += (sender, args) => { hiddenLabel.Text = "Hidden Button (Clicked)"; }; + + ContainerLayout = new StackLayout { + AutomationId = formsMember + "Container", + Padding = 10, + Children = { TitleLabel, BoundsLabel, layout, hiddenLabel } + }; + } + } +} \ No newline at end of file -- cgit v1.2.3