Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jamesdouble/JDVideoKit
https://github.com/jamesdouble/JDVideoKit
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/jamesdouble/JDVideoKit
- Owner: jamesdouble
- License: mit
- Created: 2017-08-05T07:14:25.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2019-10-10T03:20:59.000Z (over 5 years ago)
- Last Synced: 2024-12-05T08:16:31.502Z (3 months ago)
- Language: Swift
- Size: 2.56 MB
- Stars: 25
- Watchers: 5
- Forks: 5
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - JDVideoKit - You can easily transfer your video into Three common video type via this framework. (Media / Video)
- awesome-ios-star - JDVideoKit - You can easily transfer your video into Three common video type via this framework. (Media / Video)
README

# JDVideoKit



# Introduction
You can easily transfer your video into Three common video type.
You can use set up camera easily.
# Installation
```
pod 'JDVideoKit'
```# USAGE
### 1.[Use My Two Layout](#use-my-two-layout)
### 2.[Use Only Capturing Layout](#use-only-capturing-layout)
### 3.[Use Only Editing Layout](#use-only-editing-layout)
### 4.[Convert Video Directly](#convert-video-directly)
### [Customize your Layout](#customization)
## Delegate
```swift
public protocol JDVideoKitDelegate {
//1.If return nil means call JDProcessingViewController
func videoResource(forkit kit:JDVideoKit)->Any?
//2.Only will call when above function return nil. Can make some setting for JDProcessingViewController
func willPresent(cameraViewController vc:JDProcessingViewController,forkit:JDVideoKit)->JDProcessingViewController
//3.Can make some setting for JDPresentingViewController, if return nil jump to next delegate
func willPresent(edtingViewController vc:JDPresentingViewController,lastVC:UIViewController?,forkit:JDVideoKit)->JDPresentingViewController?
//4.Set your type
func ConvertType(forVideo resource:Any,forkit:JDVideoKit)->videoProcessType
//5.Call When user click save.
func FinalOutput(final video:AVAsset,url:URL)
}```
1. ***(NonOptional)***
Return the video resource if you allready have one and Skip to Delegate 3.
**Resource Allow Type : URL , AVAsset**
Return nil, will call Capturing Layout.
2. ***(Optional)***You can make some setting to customize [ProcessingViewController](#processingViewController) and return it.
3. ***(Optional)***
Call when Capturing Finish or delegate provide an avaliable video.
You can make some setting to customize [PresentingViewController](#PresentingViewController) and return it.
Return nil if you don't need edting layout and end it here , skip to 5.
**If you use capturing Layout before and you won't use editing Layout next, you should use the para "LastVC" to dissmiss it or whatever you want**4. ***(Optional)***
Specific the Convert type. **(.Boom , .Speed , .Reverse)**
5. ***(NonOptional)***
Call When user click save button in Editing Layout, Capturing without editng or direct transfer complete.
---
### Use My Two Layout
#### -> Implement 1 , 5```swift
class ViewController: UIViewController {
override func viewDidAppear(_ animated: Bool) {
let vk = JDVideoKit(delegate: self).getProperVC()
self.present(vk, animated: true, completion: nil)
}
}
extension ViewController:JDVideoKitDelegate{
func videoResource(forkit kit: JDVideoKit) -> Any? {
return nil
}
func FinalOutput(final video:AVAsset,url:URL){
print(url)
}
}
```### Use Only Capturing Layout
#### -> Implement 1 , 3 , 4 , 5**Notice** : You may need to dissmiss the ProcessingVC or it keep on screen.
```swift
class ViewController: UIViewController {
override func viewDidAppear(_ animated: Bool) {
let vk = JDVideoKit(delegate: self).getProperVC()
self.present(vk, animated: true, completion: nil)
}
}
extension ViewController:JDVideoKitDelegate
{
func videoResource(forkit kit: JDVideoKit) -> Any? {
return nil
}
func FinalOutput(final video:AVAsset,url:URL)
{
/// You will get a Video, you capture by my layout and convert
/// To the type you specific.
}
func willPresent(edtingViewController vc:JDPresentingViewController,lastVC:UIViewController?,forkit:JDVideoKit)->JDPresentingViewController? {
lastVC.dissmiss(...)
return nil
}
func ConvertType(forVideo resource: Any, forkit: JDVideoKit) -> videoProcessType {
return .Boom
}
}
```### Use Only Editing Layout
#### -> Implement 1 , 5
```swift
class ViewController: UIViewController {
override func viewDidAppear(_ animated: Bool) {
let vk = JDVideoKit(delegate: self).getProperVC()
self.present(vk, animated: true, completion: nil)
}
}
extension ViewController:JDVideoKitDelegate
{
func videoResource(forkit kit: JDVideoKit) -> Any? {
return URL( url or asset of video)
}
func FinalOutput(final video:AVAsset,url:URL)
{
print(url)
}
}
```### Convert Video Directly
#### -> Implement 1 , 4 , 5
```swift
class ViewController: UIViewController {
override func viewDidAppear(_ animated: Bool) {
let vk2 = JDVideoKit(delegate: self)
vk2.getVideoDirectly { (progress) in
print(progress)
}
}
}
extension ViewController:JDVideoKitDelegate
{
func videoResource(forkit kit: JDVideoKit) -> Any? {
return URL( url or asset of video)
}
func FinalOutput(final video:AVAsset,url:URL)
{
print(url)
}
func ConvertType(forVideo resource: Any, forkit: JDVideoKit) -> videoProcessType {
return .Boom
}
}```
---
### Customization#### ProcessingViewController
Implement this Delegate:
```Swift
func willPresent(cameraViewController vc:JDProcessingViewController,forkit:JDVideoKit)->JDProcessingViewController
{
///Set Below Variable Like this
vc.enableFlashLight = false
}
```The component you can customize:
```swift
public var enableFlashLight:Bool = true
public var FlashLightIconColor:UIColor = UIColor.black
public var SwitchIconColor:UIColor = UIColor.white
public var CaptureIconColor:UIColor = UIColor.white
public var allowChooseFromLibrary:Bool = true
public var BackgroundViewBarColor:UIColor?
```
#### ProcessingViewController
Implement this Delegate:
```Swift
func willPresent(edtingViewController vc:JDPresentingViewController,lastVC:UIViewController?,forkit:JDVideoKit)->JDPresentingViewController?
{
vc.topTitle = "Title"
}
```The component you can customize:
```swift
public var topTitle:String = "Share"
public var CloseIconColor:UIColor = UIColor.white
public var saveButtonTitle:String = "Save"
public var savaButtonColor:UIColor = UIColor.white
```