PatternLockView


Source link: https://github.com/aritraroy/PatternLockView

PatternLockView

An easy-to-use, customizable, Material Design ready Pattern Lock view for Android.

Specs

This library allows you to implement pattern locking mechanism in your app easily and quickly. It is very easy to use and there are plenty of customization options available to change the functionality and look-and-feel of this view to match your needs.

It also supports RxJava 2 view bindings, so if you are a fan of reactive programming (just like me), you can get a stream of updates as the user draws the pattern.

Download

This library is available in jCenter which is the default Maven repository used in Android Studio.

Gradle

dependencies {

  // other dependencies here

 compile 'com.andrognito.patternlockview:patternlockview:1.0.0'
  // Optional, for RxJava2 adapter
  compile 'com.andrognito.patternlockview:patternlockview-reactive:1.0.0' 
}

Spread Some ❤?


Usage

We recommend you to check the sample project to get a complete understanding of the library. The step-by-step implementation guide is as follows.

Step 1

Place the view in your XML layout file.

 <com.andrognito.patternlockview.PatternLockView

android:id="@+id/pattern_lock_view"

android:layout_width="280dp"

android:layout_height="280dp"/>

This is enough to get the view rendered in your layout. But you would certainly want to add a callback listener to listen to pattern changes.

Step 2

Reference the view in code and add a listener to it.

mPatternLockView = (PatternLockView) findViewById(R.id.pattern_lock_view);
 mPatternLockView.addPatternLockListener(mPatternLockViewListener);

Implement the listener interface as follows,

private PatternLockViewListener mPatternLockViewListener = new PatternLockViewListener() {

@Override

public void onStarted() {

 Log.d(getClass().getName(), "Pattern drawing started");

}

 @Override

public void onProgress(List<PatternLockView.Dot> progressPattern) {

 Log.d(getClass().getName(), "Pattern progress: " +

PatternLockUtils.patternToString(mPatternLockView, progressPattern));

}

 @Override

public void onComplete(List<PatternLockView.Dot> pattern) {

 Log.d(getClass().getName(), "Pattern complete: " +

PatternLockUtils.patternToString(mPatternLockView, pattern));

}

 @Override

public void onCleared() {

 Log.d(getClass().getName(), "Pattern has been cleared");

}

  
}
;

And that's it! Your PatternLockView is ready to rock. You might also want to remove the listeners when not needed, removePatternLockListener(mPatternLockViewListener);

Step 3 (Optional: ReactiveX Interface)

For the RxJava fanboys, this library supports RxJava 2 view bindings. You can subscribe to this view to get a stream of pattern change updates.

RxPatternLockView.patternChanges(mPatternLockView)

  .subscribe(new Consumer<PatternLockCompoundEvent>() {

@Override

public void accept(PatternLockCompoundEvent event) throws Exception {

 if (event.getEventType() == PatternLockCompoundEvent.EventType.PATTERN_STARTED) {

  Log.d(getClass().getName(), "Pattern drawing started");

 
}
 else if (event.getEventType() == PatternLockCompoundEvent.EventType.PATTERN_PROGRESS) {

  Log.d(getClass().getName(), "Pattern progress: " +

 PatternLockUtils.patternToString(mPatternLockView, event.getPattern()));

 
}
 else if (event.getEventType() == PatternLockCompoundEvent.EventType.PATTERN_COMPLETE) {

  Log.d(getClass().getName(), "Pattern complete: " +

 PatternLockUtils.patternToString(mPatternLockView, event.getPattern()));

 
}
 else if (event.getEventType() == PatternLockCompoundEvent.EventType.PATTERN_CLEARED) {

  Log.d(getClass().getName(), "Pattern has been cleared");

 
}

}

  
}
);

If you are not interested in getting the compound event, you should subscribe to patternComplete() and/or patternProgress() for the specific updates. Have a detailed look here.

Customization

There are several customization options available which you can use to completely change the look-and-feel and functionality of this view to match your needs.

XML (Quick and Easy)

You can add various attributes to the PatternLockView from your XML layout.

  app:dotCount="3"

 // Change the no.of dots in a row (or column)
app:dotNormalSize="12dp"

  // Change the size of the dots in normal state
app:dotSelectedSize="24dp"

// Change the size of the dots in selected state
app:pathWidth="4dp"

 // Change the width of the path
app:aspectRatioEnabled="true"

// Set if the view should respect custom aspect ratio
app:aspectRatio="square"

  // Set between "square", "width_bias", "height_bias"
app:normalStateColor="@color/white"

// Set the color of the pattern view in normal state
app:correctStateColor="@color/primary"

// Set the color of the pattern view in correct state
app:wrongStateColor="@color/pomegranate"

 // Set the color of the pattern view in error state

  app:dotAnimationDuration="200"

  // Change the duration of the animating dots
app:pathEndAnimationDuration="100"

 // Change the duration of the path end animaiton

JAVA (Programatically)

You can also programatically change the properties of the view, thereby having more control over it.

mPatternLockView.setViewMode(PatternLockView.PatternViewMode.CORRECT);

 // Set the current viee more  mPatternLockView.setInStealthMode(true);

 // Set the pattern in stealth mode (pattern drawing is hidden) mPatternLockView.setTactileFeedbackEnabled(true);

 // Enables vibration feedback when the pattern is drawn mPatternLockView.setInputEnabled(false);

 // Disables any input from the pattern lock view completely  mPatternLockView.setDotCount(3);
 mPatternLockView.setDotNormalSize((int) ResourceUtils.getDimensionInPx(this, R.dimen.pattern_lock_dot_size));
 mPatternLockView.setDotSelectedSize((int) ResourceUtils.getDimensionInPx(this, R.dimen.pattern_lock_dot_selected_size));
 mPatternLockView.setPathWidth((int) ResourceUtils.getDimensionInPx(this, R.dimen.pattern_lock_path_width));
 mPatternLockView.setAspectRatioEnabled(true);
 mPatternLockView.setAspectRatio(PatternLockView.AspectRatio.ASPECT_RATIO_HEIGHT_BIAS);
  mPatternLockView.setNormalStateColor(ResourceUtils.getColor(this, R.color.white));
 mPatternLockView.setCorrectStateColor(ResourceUtils.getColor(this, R.color.primary));
 mPatternLockView.setWrongStateColor(ResourceUtils.getColor(this, R.color.pomegranate));
 mPatternLockView.setDotAnimationDuration(150);
 mPatternLockView.setPathEndAnimationDuration(100);
 

Contribution

This library is inspired from AOSP's LockPatternView. There are lots of improvements and customization options added so that you can get started without any hassle. If you find a bug or would like to improve any aspect of it, feel free to contribute with pull requests.

About The Author

Aritra Roy

Android & Backend Developer. Blogger. Designer. Fitness Enthusiast.

License

Copyright 2017 aritraroy  Licensed under the Apache License, Version 2.0 (the "License");
 you may not use this file except in compliance with the License. You may obtain a copy of the License at
  http://www.apache.org/licenses/LICENSE-2.0  Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. 

Resources

Lite Android swipeable deck view.

Country Code Picker (CCP) is an android library which provides an easy way to search and select country phone code for the telephone number.

HyperTrack Live open source repo uses HyperTrack to enable location sharing and real-time tracking of your friends and family. Scrape parts of this app to add live location sharing into your own app, or fork the repo and modify it to your own need to build your own brand new app.

A bunch of scripts you can use to compile FFmpeg with OpenSSL.

A picker of Local Government Areas and States for Nigerian developers.

Trialy makes it easy to create a free trial for your in-app-purchases. Trialy takes care of the heavy lifting for you (using server-side checks with customizable grace periods to allow for offline use, for example) so you can focus on developing an amazing app. In addition to configuring the trial length, you can decide whether users should be able to try your app on each of their device, or just once for each Google account.

Topics


2D Engines   3D Engines   9-Patch   Action Bars   Activities   ADB   Advertisements   Analytics   Animations   ANR   AOP   API   APK   APT   Architecture   Audio   Autocomplete   Background Processing   Backward Compatibility   Badges   Bar Codes   Benchmarking   Bitmaps   Bluetooth   Blur Effects   Bread Crumbs   BRMS   Browser Extensions   Build Systems   Bundles   Buttons   Caching   Camera   Canvas   Cards   Carousels   Changelog   Checkboxes   Cloud Storages   Color Analysis   Color Pickers   Colors   Comet/Push   Compass Sensors   Conferences   Content Providers   Continuous Integration   Crash Reports   Credit Cards   Credits   CSV   Curl/Flip   Data Binding   Data Generators   Data Structures   Database   Database Browsers   Date &   Debugging   Decompilers   Deep Links   Dependency Injections   Design   Design Patterns   Dex   Dialogs   Distributed Computing   Distribution Platforms   Download Managers   Drawables   Emoji   Emulators   EPUB   Equalizers &   Event Buses   Exception Handling   Face Recognition   Feedback &   File System   File/Directory   Fingerprint   Floating Action   Fonts   Forms   Fragments   FRP   FSM   Functional Programming   Gamepads   Games   Geocaching   Gestures   GIF   Glow Pad   Gradle Plugins   Graphics   Grid Views   Highlighting   HTML   HTTP Mocking   Icons   IDE   IDE Plugins   Image Croppers   Image Loaders   Image Pickers   Image Processing   Image Views   Instrumentation   Intents   Job Schedulers   JSON   Keyboard   Kotlin   Layouts   Library Demos   List View   List Views   Localization   Location   Lock Patterns   Logcat   Logging   Mails   Maps   Markdown   Mathematics   Maven Plugins   MBaaS   Media   Menus   Messaging   MIME   Mobile Web   Native Image   Navigation   NDK   Networking   NFC   NoSQL   Number Pickers   OAuth   Object Mocking   OCR Engines   OpenGL   ORM   Other Pickers   Parallax List   Parcelables   Particle Systems   Password Inputs   PDF   Permissions   Physics Engines   Platforms   Plugin Frameworks   Preferences   Progress Indicators   ProGuard   Properties   Protocol Buffer   Pull To   Purchases   Push/Pull   QR Codes   Quick Return   Radio Buttons   Range Bars   Ratings   Recycler Views   Resources   REST   Ripple Effects   RSS   Screenshots   Scripting   Scroll Views   SDK   Search Inputs   Security   Sensors   Services   Showcase Views   Signatures   Sliding Panels   Snackbars   SOAP   Social Networks   Spannable   Spinners   Splash Screens   SSH   Static Analysis   Status Bars   Styling   SVG   System   Tags   Task Managers   TDD &   Template Engines   Testing   Testing Tools   Text Formatting   Text Views   Text Watchers   Text-to   Toasts   Toolkits For   Tools   Tooltips   Trainings   TV   Twitter   Updaters   USB   User Stories   Utils   Validation   Video   View Adapters   View Pagers   Views   Watch Face   Wearable Data   Wearables   Weather   Web Tools   Web Views   WebRTC   WebSockets   Wheel Widgets   Wi-Fi   Widgets   Windows   Wizards   XML   XMPP   YAML   ZIP Codes