diff options
author | Jason Smith <jason.smith@xamarin.com> | 2016-03-22 13:02:25 -0700 |
---|---|---|
committer | Jason Smith <jason.smith@xamarin.com> | 2016-03-22 16:13:41 -0700 |
commit | 17fdde66d94155fc62a034fa6658995bef6fd6e5 (patch) | |
tree | b5e5073a2a7b15cdbe826faa5c763e270a505729 /Xamarin.Forms.Platform.iOS/LayoutExtensions.cs | |
download | xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.gz xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.bz2 xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.zip |
Initial import
Diffstat (limited to 'Xamarin.Forms.Platform.iOS/LayoutExtensions.cs')
-rw-r--r-- | Xamarin.Forms.Platform.iOS/LayoutExtensions.cs | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/Xamarin.Forms.Platform.iOS/LayoutExtensions.cs b/Xamarin.Forms.Platform.iOS/LayoutExtensions.cs new file mode 100644 index 00000000..6e7f5738 --- /dev/null +++ b/Xamarin.Forms.Platform.iOS/LayoutExtensions.cs @@ -0,0 +1,36 @@ +using System.Collections.Generic; +#if __UNIFIED__ +using CoreGraphics; +using UIKit; + +#else +using MonoTouch.UIKit; +#endif + +#if !__UNIFIED__ + // Save ourselves a ton of ugly ifdefs below +using CGSize = System.Drawing.SizeF; +#endif + +namespace Xamarin.Forms.Platform.iOS +{ + public delegate SizeRequest? GetDesiredSizeDelegate(NativeViewWrapperRenderer renderer, double widthConstraint, double heightConstraint); + + public delegate CGSize? SizeThatFitsDelegate(CGSize size); + + public delegate bool LayoutSubviewsDelegate(); + + public static class LayoutExtensions + { + public static void Add(this IList<View> children, UIView view, GetDesiredSizeDelegate getDesiredSizeDelegate = null, SizeThatFitsDelegate sizeThatFitsDelegate = null, + LayoutSubviewsDelegate layoutSubViews = null) + { + children.Add(view.ToView(getDesiredSizeDelegate, sizeThatFitsDelegate, layoutSubViews)); + } + + public static View ToView(this UIView view, GetDesiredSizeDelegate getDesiredSizeDelegate = null, SizeThatFitsDelegate sizeThatFitsDelegate = null, LayoutSubviewsDelegate layoutSubViews = null) + { + return new NativeViewWrapper(view, getDesiredSizeDelegate, sizeThatFitsDelegate, layoutSubViews); + } + } +}
\ No newline at end of file |