ElegantPopover
ElegantPopover copied to clipboard
Highly customisable popover with multiple borders, borders styles (color and gradient) and arrow styles in iOS.
data:image/s3,"s3://crabby-images/1ddaf/1ddaf82e0cf54a738233c76a87eec9eaf83658a2" alt=""
Elegant Popover
Highly customisable popovers with multiple borders, borders styles (color and gradient) and arrow styles in iOS.
Features
- [x] Border with Color or Gradient (Any layer).
- [x] Multiple Borders for a Popover.
- [x] Customisable Arrow shape.
- [x] Solid and Outlined Arrow.
data:image/s3,"s3://crabby-images/81a66/81a66120bdef1545c9dbe474557efff4f5fe331f" alt=""
data:image/s3,"s3://crabby-images/8ea04/8ea04e2a5163caaeb9870d982b68ea9e3dbf9291" alt=""
Requirements
- Swift 4
- iOS 11 and above
Installation
ElegantPopover is available on CocoaPods.
Add this line to your Podfile
.
pod 'ElegantPopover'
Run pod install
.
Dependencies
This library depends on ClippingBezier library.
Usage
// In your view controller
let arrow = PSArrow(height: 25, base: 35, baseCornerRadius: 0, direction: .up)
var design = PSDesign()
design.backGroundColor = UIColor.white
// 'contentView' is the UIView which contains 'Elegant Popover' UILabel
let popoverController = ElegantPopoverController(contentView: contentView,
design: design,
arrow: arrow,
sourceView: view,
sourceRect: CGRect(origin: CGPoint(x: 100, y: 170), size:CGSize.zero))
present(popoverController, animated: true)
data:image/s3,"s3://crabby-images/3a590/3a5905b126a77dcc236ec1e30259dbc6862eeab0" alt=""
Customisations
Note: The following customisations are to be done before creating an instance of ElegantPopoverController
Gradient border
let gradient = CAGradientLayer()
gradient.colors = [UIColor(red: CGFloat(222/255.0),
green: CGFloat(98/255.0),
blue: CGFloat(98/255.0),
alpha: CGFloat(1.0)).cgColor,
UIColor(red: CGFloat(255/255.0),
green: CGFloat(184/255.0),
blue: CGFloat(140/255.0),
alpha: CGFloat(1.0)).cgColor]
gradient.startPoint = CGPoint(x: 0, y: 0)
gradient.endPoint = CGPoint(x: 1, y: 1)
design.borders = [PSBorder(filling: .layer(gradient), width: 12)]
data:image/s3,"s3://crabby-images/bf83c/bf83c37cecdc574217cc86feee24c7397aa933f7" alt=""
Insets of popover
design.insets = UIEdgeInsets(top: 20, left: 20, bottom: 20, right: 20)
data:image/s3,"s3://crabby-images/02c74/02c74f5df68fbd4bc2017c6be0dd065d725220b3" alt=""
Corner radius of popover
design.cornerRadius = 15
data:image/s3,"s3://crabby-images/89b07/89b07a98506c70fab039f6522495819e4fd415e9" alt=""
Arrow direction
Can be set as .any
for the popover to figure out appropriate direction on its own
arrow.direction = .left
data:image/s3,"s3://crabby-images/e9da7/e9da733c21cdb46c06affc211fb331e41444194d" alt=""
Customise arrow shape
arrow.height = 60
arrow.base = 140
data:image/s3,"s3://crabby-images/f2e8d/f2e8d19ea0469001ed9d96d94b3b411d65daf58e" alt=""
Multiple borders
Multiple borders consisting of either UIColor
or CALayer
can be added in any combination
design.borders = [PSBorder(filling: .layer(gradient), width: 12),
PSBorder(filling: .pureColor(UIColor(red: CGFloat(255/255.0),
green: CGFloat(184/255.0),
blue: CGFloat(140/255.0),
alpha: CGFloat(1.0))), width: 8)]
data:image/s3,"s3://crabby-images/c9cfb/c9cfb05d1e69d993b25bbe548198f95fce6bf087" alt=""
Solid Arrow
The index of border required to take the shape of a solid arrow and not outline it. Indices go from outermost border starting with 0
to innermost. Default value is nil
which means all the borders will outline the arrow.
design.solidArrowBorderIndex = 1
data:image/s3,"s3://crabby-images/3f7c4/3f7c4e021025cbe1c7c27ac7facd51f2109ef58f" alt=""
Anchor to UIBarButtonItem
let popoverController = ElegantPopoverController(contentView: contentView,
design: design,
arrow: arrow,
barButtonItem: barButtonItem)
To adjust the arrow position to barButtonItem
arrow.height = 25
arrow.base = 45
data:image/s3,"s3://crabby-images/51c64/51c64bf0630c3cf02322d451293771893c2d409c" alt=""
License
This project is licensed under the MIT License - see the LICENSE file for details