背景:Core Graphicsを使用したUIImageViewで描画しています。私は最終的にコアグラフィックス図面上にテキスト文字列を描画したいと思います。Swift 3のCore Graphics上にテキストを描画する。
This (hackingwithswift.com)私は画像にテキストを描画し、その画像にmy imageViewを設定してからコアグラフィックスを描画します。しかし、私はテキストをコアグラフィックスの描画の上に重ねることを望みます。
今私はこのhttps://stackoverflow.com/a/35574171/6337391に移動しましたが、私はまだ私の図面の上に書くことができません。
class MapViewController: UIViewController {
@IBOutlet var imageView: UIImageView!
func drawScale() {
// establish 6 points to draw a little bar with
let length = CGFloat(80.0)
let bottom = imageView.bounds.size.height - 15.0
let left = CGFloat(20.0)
let top = bottom - 20.0
let middle = top + 10.0
let right = left + length
let topLeft = CGPoint(x: left, y: top)
let topRight = CGPoint(x: right, y: top)
let bottomRight = CGPoint(x: right, y: bottom)
let bottomLeft = CGPoint(x: left, y: bottom)
let middleLeft = CGPoint(x: left, y: middle)
let middleRight = CGPoint(x: right, y: middle)
// draw the bar
drawLineFrom(fromPoint: topLeft, toPoint: bottomLeft, color: UIColor.red.cgColor, width: 1.0, alias: false)
drawLineFrom(fromPoint: topRight, toPoint: bottomRight, color: UIColor.red.cgColor, width: 1.0, alias: false)
drawLineFrom(fromPoint: middleLeft, toPoint: middleRight, color: UIColor.red.cgColor, width: 1.0, alias: false)
// draw a text string
UIGraphicsBeginImageContext(self.imageView.frame.size)
let paragraphStyle = NSMutableParagraphStyle()
paragraphStyle.alignment = .center
let attrs = [
NSFontAttributeName: UIFont.systemFont(ofSize: 12),
NSParagraphStyleAttributeName: paragraphStyle,
NSForegroundColorAttributeName: UIColor.red]
let scaleString = "45 feet"
scaleString.draw(at: CGPoint(x: 0, y: 50), withAttributes: attrs)
let newImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
}
/* Stroke a line between two CGPoints. Color, width, anti-alias options. */
func drawLineFrom(fromPoint: CGPoint, toPoint: CGPoint, color: CGColor, width: CGFloat, alias: Bool) {
// 1
UIGraphicsBeginImageContext(self.imageView.frame.size)
let context = UIGraphicsGetCurrentContext()!
context.setShouldAntialias(alias)
self.imageView.image?.draw(in: CGRect(x: 0, y: 0, width: self.imageView.frame.size.width, height: self.imageView.frame.size.height))
// 2
context.move(to: fromPoint)
context.addLine(to: toPoint)
// 3
context.setLineWidth(width)
context.setStrokeColor(color)
// 4
context.strokePath()
// 5
self.imageView.image = UIGraphicsGetImageFromCurrentImageContext()
self.imageView.alpha = 1.0
UIGraphicsEndImageContext()
}
}
doesnt work。テキスト文字列を描画すると、バーが完全に消去されます。文字列描画コードの下にバー描画コードを移動すると、両方が表示されますが、もちろんバーは文字列の上にあります。
あなたがCATextLayerにテキストを作成し、画像ビューに追加してもらえますか? – dfd
「コアグラフィックスを使用したUIImageViewを描画しています」とは何を意味し、どのクラスでコードを実行していますか? –
文脈コードを少し追加しました。役立つと思います。答えはCore Textの中にあると思います。私はその道を自分で解決しようとします。あなたはUIGraphicsBeginImageContextを削除した点で私のコードと異なるだけです。(リンク先はhttp://stackoverflow.com/questions/27052665/swift-playground-core-graphics-core-text-custom-view) –