zoukankan      html  css  js  c++  java
  • Xamarin.Forms 手势密码实现

    Xamarin.Forms 手势密码实现

    在前面的文章中,讲到了Xamarin.Android、Xamarin.iOS、UWP分别实现手势密码功能,现在我们在Xamarin.Forms中来实现这个功能。

      

    原理和Xamarin.Android、Xamarin.iOS、UWP一样,关键就是如何使用ViewRenderer。

    首先我们新建Xamarin.Forms项目:

    在项目中创建GuestureLockView继承View(官方文档: 自定义Renderer)。

    接下来分别在Android、iOS、UWP项目中创建GuestureLockViewRenderer

    Android中 : GuestureLockViewRenderer继承ViewRenderer<GuestureLockView, Android.Views.View>

    iOS中: GuestureLockViewRenderer继承ViewRenderer<GuestureLockView, UIView>

    UWP中: GuestureLockViewRenderer继承ViewRenderer<GuestureLockView, CanvasControl>,CanvasControl需要在NuGet中安装Win2D库。

    还需要在GuestureLockViewRenderer中重写protected override void OnElementChanged(ElementChangedEventArgs<GuestureLockView> e)方法。

    protected override void OnElementChanged (ElementChangedEventArgs<GuestureLockView> e)
    {
      base.OnElementChanged (e);
    
      if (Control == null) {
        // Instantiate the native control and assign it to the Control property with
        // the SetNativeControl method
      }
    
      if (e.OldElement != null) {
        // Unsubscribe from event handlers and cleanup any resources
      }
    
      if (e.NewElement != null) {
        // Configure the control and subscribe to event handlers
      }
    }

    控件在加载时,会调用该方法。原文如下说明:

    An overridden version of the OnElementChanged method, in each platform-specific renderer class, is the place to perform the native control instantiation and customization. The SetNativeControl method should be used to instantiate the native control, and this method will also assign the control reference to the Control property.

    然后就是在GuestureLockViewRenderer根据各个平台分别绘制图形,这样就能实现该需求了。

    在这是实验中,恰巧遇到 Control为null的情况(UWP中),这时需要调用SetNativeControl方法初始化一个NativeControl。

    if(Control == null)
    {
        SetNativeControl(new CanvasControl());
    }

     Github:https://github.com/devinZhou102/Plugin.GuestureLock

     Xamarin.Android手势密码:http://www.cnblogs.com/devin_zhou/p/8057243.html

     Xamarin.iOS手势密码:http://www.cnblogs.com/devin_zhou/p/8047313.html

    Xamarin.UWP手势密码:http://www.cnblogs.com/devin_zhou/p/8052305.html

  • 相关阅读:
    ES6学习笔记(五)函数的扩展
    ES6学习笔记(四)数值的扩展
    ES6学习笔记(二)变量的解构与赋值
    ES6学习笔记(一)新的变量定义命令let和const
    JS对象继承与原型链
    JS构造函数、对象工厂、原型模式
    获取地图的坐标
    大屏页面
    如何更新git?
    ES6——多个箭头函数
  • 原文地址:https://www.cnblogs.com/devin_zhou/p/8946436.html
Copyright © 2011-2022 走看看