WYMaterialButton
  • November 10, 2023
Inspired by Google Material Design, written purely in swift 3.

WYMaterialButton implemented Material Design on iOS and add more dynamic motions, allowing iOS buttons to be more responsive and interactive.

Integrated with Spring animations and enhanced by Facebook’s POP, WYMaterialButton is super animated and programmer-friendly. All settings can be customized in storyboard inspector.

Installation


WYMaterialButton is available through Cocoapods

To install via CocoaPods add this lines to your Podfile

use_frameworks!
pod “WYMaterialButton”

Note: Due to CocoaPods/CocoaPods#4420 issue there is problem with compiling project with Xcode 7.1 and CocoaPods v0.39.0. However there is a temporary workaround for this: Add next lines to the end of your Podfile

post_install do |installer|
`find Pods -regex ‘Pods/pop.*\\.h’ -print0 | xargs -0 sed -i ” ‘s/\\(<\\)pop\\/\\(.*\\)\\(>\\)/\\”\\2\\”/’`
end

Or download the git respository

git clone https://github.com/yuwang17/WYMaterialButton.git

Drag WYMaterialButton related files into your own project, and install facebook’s POP via cocoapods

Then import the module in your file

import WYMaterialButton

If you’re Objective-C user, please include the header file

#import “WYMaterialButton-Swift.h”

Usage


  1. Add a UIButton in the Storyboard of your project.

  2. Subclass the UIbutton as WYMaterialButton in identity inspector.

  3. Select a color as Material Color, the first row in attribute inspector, and let WYMaterialButton do everything else for you. You can also do other setting as well for further customizations.

Specification


  • For most cases, Material Color is the only property you need to set. Leave others as default.

  • Pulse Enable enable defautly, which control the bounce effect.

  • With Touch Location Enable enabled defautly, WYMaterialButton tracks your touch location and generate a ripple animation upon that. You can disable to always center the ripple effect on the button.

  • Material Effect Percent speicifies the percentage of area of the button will have material effect when being pressed. Default to 0.8.

  • You can of course access all these properties and more by using codes. For example:

myButton.materialColor = .blue

Demo


  1. Download the repository

git clone https://github.com/yuwang17/WYMaterialButton.git
cd WYMaterialButton/Example

  1. Open the workspace

open WYMaterialButton.xcworkspace

  1. Compile and run the app in simulator
  • Under Xcode, press Ctrl + R

Supported OS & SDK Versions


  • Xcode 7
  • iOS 7

GitHub


View Github

#button #component #ios #library #materialdesign #swift
YOU MIGHT ALSO LIKE...
EEStackLayout

A vertical stackview which takes subviews with different widths and adds them to it's rows with paddings, spacings etc.

AudioManager

AudioManager is a Swift package that provides a modular and easy-to-use interface for implementing audio feedback in your applications. It ...

CameraBackground

Features Both front and back camera supported. Flash modes: auto, on, off. Countdown timer. Tap to focus. Pinch to zoom. Usage  

DKCamera

Description A light weight & simple & easy camera for iOS by Swift. It uses CoreMotion framework to detect device orientation, so ...