Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/psy2k/NMPopUpView
Simple Swift class for iOS that shows nice popup windows with animation.
https://github.com/psy2k/NMPopUpView
ios swift
Last synced: about 1 month ago
JSON representation
Simple Swift class for iOS that shows nice popup windows with animation.
- Host: GitHub
- URL: https://github.com/psy2k/NMPopUpView
- Owner: psy2k
- License: mit
- Created: 2013-12-09T15:31:35.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2022-11-02T12:08:27.000Z (about 2 years ago)
- Last Synced: 2024-12-01T07:05:16.650Z (about 1 month ago)
- Topics: ios, swift
- Language: Swift
- Homepage:
- Size: 186 KB
- Stars: 194
- Watchers: 12
- Forks: 30
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - NMPopUpView - Simple iOS class for showing nice popup windows. Swift and Objective-C versions available. (UI / Popup)
- awesome-ios-star - NMPopUpView - Simple iOS class for showing nice popup windows. Swift and Objective-C versions available. (UI / Popup)
README
[![Version](https://img.shields.io/cocoapods/v/NMPopUpViewSwift.svg?style=flat)](http://cocoapods.org/pods/NMPopUpViewSwift)
[![License](https://img.shields.io/cocoapods/l/NMPopUpViewSwift.svg?style=flat)](http://cocoapods.org/pods/NMPopUpViewSwift)
[![Platform](https://img.shields.io/cocoapods/p/NMPopUpViewSwift.svg?style=flat)](http://cocoapods.org/pods/NMPopUpViewSwift)
NMPopUpView
===========Simple class for iOS that shows nice popup windows, written in Swift. The project is build with Swift 4.0, so you need Xcode 9.0 or higher to use it.
## Installation
### Automatic installation using CocoaPods
Add this to your podfile and run `pod install`:
`````ruby
pod "NMPopUpViewSwift"
`````### Manual installation
To use it in your application, just import `PopViewControllerSwift.swift` (~~or `PopViewController.h`, `PopViewController.m` if you want to use the Objective-C version~~. If you still need the Objective-C version, download manually version 2.1 from [here](https://github.com/psy2k/NMPopUpView/releases)), `PopViewController.xib` and `PopViewController_iPad.xib`, `PopViewController_iPhone6.xib`, `PopViewController_iPhone6Plus.xib` files (or the `NMPopUpViewController` group from the example project) in your project:### Usage
To run the example project, clone the repo, and run `pod install` from the Example directory first.
#### Swift
`````swift
var popViewController : PopUpViewController = PopUpViewControllerSwift(nibName: "PopUpViewController", bundle: nil)
````````
and call the pop up using this code in Swift:
`````swift
popViewController.title = "This is a popup view"
popViewController.showInView(self.view, withImage: UIImage(named: "typpzDemo"), withMessage: "You just triggered a great popup window", animated: true)
```````````
To get the appropriate .xib for your screen size declare the popUp as a forced unrapped variable and then use a method similar to the one below in order to call it:
`````swift
var popViewController : PopUpViewControllerSwift!@IBAction func showPopUp(sender: AnyObject) {
let bundle = NSBundle(forClass: PopUpViewControllerSwift.self)
if (UIDevice.currentDevice().userInterfaceIdiom == .Pad)
{
self.popViewController = PopUpViewControllerSwift(nibName: "PopUpViewController_iPad", bundle: bundle)
self.popViewController.title = "This is a popup view"
self.popViewController.showInView(self.view, withImage: UIImage(named: "typpzDemo"), withMessage: "You just triggered a great popup window", animated: true)
} else
{
if UIScreen.mainScreen().bounds.size.width > 320 {
if UIScreen.mainScreen().scale == 3 {
self.popViewController = PopUpViewControllerSwift(nibName: "PopUpViewController_iPhone6Plus", bundle: bundle)
self.popViewController.title = "This is a popup view"
self.popViewController.showInView(self.view, withImage: UIImage(named: "typpzDemo"), withMessage: "You just triggered a great popup window", animated: true)
} else {
self.popViewController = PopUpViewControllerSwift(nibName: "PopUpViewController_iPhone6", bundle: bundle)
self.popViewController.title = "This is a popup view"
self.popViewController.showInView(self.view, withImage: UIImage(named: "typpzDemo"), withMessage: "You just triggered a great popup window", animated: true)
}
} else {
self.popViewController = PopUpViewControllerSwift(nibName: "PopUpViewController", bundle: bundle)
self.popViewController.title = "This is a popup view"
self.popViewController.showInView(self.view, withImage: UIImage(named: "typpzDemo"), withMessage: "You just triggered a great popup window", animated: true)
}
}
}
`````
#### Objective-C
`````objective-c
PopUpViewControllerSwift *popViewController = [[PopUpViewControllerSwift alloc]
initWithNibName:@"PopUpViewController" bundle:nil];
[popViewController setTitle:@"This is a popup view"];
[popViewController showInView:self.view
withImage:[UIImage imageNamed:@"yourImage"]
withMessage:@"Your Message" animated:YES];
```````````Final output is shown below:
![alt tag](http://blog.typpz.com/wp-content/popupios1.gif)
A walkthrough tutorial for the Objective-C version can be found [here](http://blog.typpz.com/2013/12/09/ios-sdk-create-a-pop-up-window/) and for the Swift version [here](http://blog.typpz.com/2015/01/31/ios-sdk-pop-up-window-in-swift/).
The MIT License (MIT)
======================
Copyright (c) 2013 Nikos MaounisPermission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
the Software without restriction, including without limitation the rights to
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
the Software, and to permit persons to whom the Software is furnished to do so,
subject to the following conditions:The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.