Swift 3.0
//
// ViewController.swift
// CoreImage003
//
// Created by Misato Morino on 2016/08/15.
// Copyright © 2016年 Misato Morino. All rights reserved.
//
import UIKit
import CoreImage
class ViewController: UIViewController {
// ベース画像.
let myInputImage = CIImage(image: UIImage(named: "sample1")!)
// ImageView.
var myImageView: UIImageView!
// ボタン.
let myButton: UIButton = UIButton()
override func viewDidLoad() {
super.viewDidLoad()
// UIImageViewの生成.
myImageView = UIImageView(frame: CGRect(x: 0, y: 0, width: self.view.frame.size.width, height: self.view.frame.size.height))
myImageView.image = UIImage(ciImage: myInputImage!)
self.view.addSubview(myImageView)
// ボタン.
myButton.frame = CGRect(x: 0, y: 0, width: 80, height: 80)
myButton.backgroundColor = UIColor.orange
myButton.layer.masksToBounds = true
myButton.setTitle("Crop", for: UIControlState.normal)
myButton.setTitleColor(UIColor.white, for: UIControlState.normal)
myButton.layer.cornerRadius = 40.0
myButton.layer.position = CGPoint(x: self.view.frame.width/2, y:self.view.frame.height - 50)
myButton.tag = 1
myButton.addTarget(self, action: #selector(ViewController.onClickMyButton(sender:)), for: .touchUpInside)
// 背景色を黒.
self.view.backgroundColor = UIColor.black
// UIボタンをViewに追加.
self.view.addSubview(myButton);
}
// ボタンイベント.
func onClickMyButton(sender: UIButton){
// CIFilterを生成。nameにどんなを処理するのか記入.
let myCropFilter = CIFilter(name: "CICrop")
// myScaleFilterに必要なパラメータを渡していく.
// myInputImageをInputImageとして渡す.
myCropFilter!.setValue(myInputImage, forKey: kCIInputImageKey)
// 画像のトリミングする部分の座標とサイズを渡す.
myCropFilter!.setValue(CIVector(x: 0, y: 300, z: 175, w: 300), forKey: "inputRectangle")
// フィルターを通した画像をアウトプット.
let myOutputImage : CIImage = myCropFilter!.outputImage!
// 再びUIViewにセット.
myImageView.frame = CGRect(x: 0, y: 0, width: 175, height: 300)
myImageView.image = UIImage(ciImage: myOutputImage)
// 再描画.
myImageView.setNeedsDisplay()
}
}
Swift 2.3
//
// ViewController.swift
// CoreImage003
//
// Created by Misato Morino on 2016/08/15.
// Copyright © 2016年 Misato Morino. All rights reserved.
//
import UIKit
import CoreImage
class ViewController: UIViewController {
// ベース画像.
let myInputImage = CIImage(image: UIImage(named: "sample1")!)
// ImageView.
var myImageView: UIImageView!
// ボタン.
let myButton: UIButton = UIButton()
override func viewDidLoad() {
super.viewDidLoad()
// UIImageViewの生成.
myImageView = UIImageView(frame: CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height))
myImageView.image = UIImage(CIImage: myInputImage!)
self.view.addSubview(myImageView)
// ボタン.
myButton.frame = CGRectMake(0,0,80,80)
myButton.backgroundColor = UIColor.orangeColor();
myButton.layer.masksToBounds = true
myButton.setTitle("Crop", forState: UIControlState.Normal)
myButton.setTitleColor(UIColor.whiteColor(), forState: UIControlState.Normal)
myButton.layer.cornerRadius = 40.0
myButton.layer.position = CGPoint(x: self.view.frame.width/2, y:self.view.frame.height - 50)
myButton.tag = 1
myButton.addTarget(self, action: #selector(ViewController.onClickMyButton(_:)), forControlEvents: .TouchUpInside)
// 背景色を黒.
self.view.backgroundColor = UIColor.blackColor()
// UIボタンをViewに追加.
self.view.addSubview(myButton);
}
// ボタンイベント.
func onClickMyButton(sender: UIButton){
// CIFilterを生成。nameにどんなを処理するのか記入.
let myCropFilter = CIFilter(name: "CICrop")
// myScaleFilterに必要なパラメータを渡していく.
// myInputImageをInputImageとして渡す.
myCropFilter!.setValue(myInputImage, forKey: kCIInputImageKey)
// 画像のトリミングする部分の座標とサイズを渡す.
myCropFilter!.setValue(CIVector(x: 0, y: 300, z: 175, w: 300), forKey: "inputRectangle")
// フィルターを通した画像をアウトプット.
let myOutputImage : CIImage = myCropFilter!.outputImage!
// 再びUIViewにセット.
myImageView.frame = CGRectMake(0, 0, 175, 300)
myImageView.image = UIImage(CIImage: myOutputImage)
// 再描画.
myImageView.setNeedsDisplay()
}
}
2.xと3.xの差分
init(CIImage:) から init(ciImage:) に変更
Be the first to comment
You can use [html][/html], [css][/css], [php][/php] and more to embed the code. Urls are automatically hyperlinked. Line breaks and paragraphs are automatically generated.