data:image/s3,"s3://crabby-images/ea860/ea8609022b21954c8db67b301451b0f9eaef0a8b" alt="見出し画像"
【徒然iOS】気ままにUIKit12〜UIProgress〜
概要
このマガジンは四十を過ぎたおっさんが、
を参考にStoryboardでiOSアプリを完全に趣味で楽しんでいるだけな記事を気ままに上げてます。
今回
をやる〜〜〜〜〜!
前準備
念の為、バックアップ
新しいクラス
ビューコントローラの追加
イニシャルビューの変更
をいつも通りやってから本題へ💃
data:image/s3,"s3://crabby-images/b99f6/b99f61b04d8b309cb583a40da3b3d26762027c67" alt=""
本題
⒈部品の配置
data:image/s3,"s3://crabby-images/ac74b/ac74b35b8a4d29a681dd1590d888868fd3d7fdf7" alt=""
⒉記事に合わせてプログレスビューのアトリビュートを設定
data:image/s3,"s3://crabby-images/bcf16/bcf1658130c4a76757d2bd70182f8a1c2d41b60d" alt=""
data:image/s3,"s3://crabby-images/01188/011886776a43fb38d2d938d0923868f379848709" alt=""
⒊記事どおりに接続
data:image/s3,"s3://crabby-images/b968f/b968fc13bbc9605f4be94036be9c4e39b11be837" alt=""
ラベルとプログレスビュー : Outlet接続
ボタン : Action接続
⒋シミュレータで実行
data:image/s3,"s3://crabby-images/ab8ca/ab8cad9c5da646e3cb36f4a074d57c47faaae9a1" alt=""
⒌レイアウトをちょっと変更💦
data:image/s3,"s3://crabby-images/a7ae7/a7ae73c394805726bab765d2e9a3a2d4346afbdf" alt=""
⒍CGAffineTransformMakeScale(1.0, 10.0)で太くしてみる
data:image/s3,"s3://crabby-images/2b504/2b504b35e80764478a631342277c1e1315adc97e" alt=""
⒎ちょっと追加
プログレスバー=進捗表示
なんだけど、これまでの処理だとボタンを押して手動なので、
を追加してみよう
これまでの機能が加算だから、この記事の機能も加算に変更して、
data:image/s3,"s3://crabby-images/65e6b/65e6b304fb3101eea6388b82655a3463ef6d4093" alt=""
data:image/s3,"s3://crabby-images/9091c/9091c3ab96b6d9857462f0679d208532024b1db6" alt=""
data:image/s3,"s3://crabby-images/79c21/79c21ecc081f52205dfde41ec0b831232b389f5a" alt=""
できたね。。。
なんかアニメーションもついて、プログレスバーっぽくなった🕺
今回のコード
class ProgressViewController: UIViewController {
override func viewDidLoad() {
//太く
myProgressView.transform = CGAffineTransformMakeScale(1.0, 10.0)
super.viewDidLoad()
// Do any additional setup after loading the view.
}
@IBOutlet weak var myProgressLabel: UILabel!
@IBOutlet weak var myProgressView: UIProgressView!
@IBAction func myProgressButton(_ sender: UIButton) {
//現在の進捗に10%を加算する。
myProgressView.setProgress(myProgressView.progress + 0.1, animated: true)
//ラベルに進捗率を表示する。
myProgressLabel.text = "\(Int(myProgressView.progress * 100))%完了"
}
/*https://dev.classmethod.jp/articles/ios-uiprogressview-progress/
を追加
*/
private func reset() {
myProgressView.progress = 0.1
}
private func setProgress(progress: Float, animated: Bool) {
CATransaction.setCompletionBlock {
NSLog("終了")
}
myProgressView.setProgress(progress, animated: animated)
NSLog("開始")
}
@IBAction func noAnimation0Button(_ sender: UIButton) {
setProgress(progress: 1.0, animated: false)
}
@IBAction func noAnimation5Button(_ sender: UIButton) {
setProgress(progress: 5.0, animated: false)
}
@IBAction func noAnimation10Button(_ sender: UIButton) {
setProgress(progress: 10.0, animated: false)
}
@IBAction func animation0Button(_ sender: UIButton) {
setProgress(progress: 1.0, animated: true)
}
@IBAction func animation5Button(_ sender: UIButton) {
setProgress(progress: 5.0, animated: true)
}
@IBAction func animation10Button(_ sender: UIButton) {
setProgress(progress: 10.0, animated: true)
}
@IBAction func progressResetButton(_ sender: UIButton) {
reset()
}
}
Apple公式
と、ここまでで機能については以上なんだけど
Appleの英語記事を日本語で表示する方法
で、
「でも、英語なんです。そこさえクリアできれば、あと時間があればやり放題ですね。」
てところがあったので
(知ってる人の方が多いだろうけど)
以下のいずれか
⒈ GoogleChromeで開いて日本語に翻訳させる
data:image/s3,"s3://crabby-images/6125d/6125d5929dacae0a66e26d4fd57e1b0fc53f901d" alt=""
data:image/s3,"s3://crabby-images/dc4bf/dc4bf0ec82eb86d2e42f7579ecd99130debc7151" alt=""
⒉Safariで開く
data:image/s3,"s3://crabby-images/b542b/b542b197fb79c60db97d4f1120025bc211719d19" alt=""
data:image/s3,"s3://crabby-images/94d15/94d15712e842febc1d472b519bc12b45ff85cd7f" alt=""
data:image/s3,"s3://crabby-images/86f69/86f6928fa47f56ac4039d7308709d997dbf680c5" alt=""
data:image/s3,"s3://crabby-images/9e297/9e2975ca16b4e961e674b6ec673ff3e454c3737b" alt=""
ChromeとSafariのどっちがいいのか?
個人的には、
AppleのサービスやHP :Safari
GoogleのサービスやHP :Chrome
で使い分けてるね〜〜〜〜
Apple公式
に載せてるリンクをChromeでやってたんだけど、Safariに比べてやっぱり訳がおかしかったりが多かったので、自社サービスの記事を訳すときは、その会社が出してるブラウザで翻訳機能を使うのが一番だね。
さてと、
ちょっと年末年始の休憩がてら、気ままにちょっと記事を作ってきたけど、
UIKitよりはやっぱりSwiftUIの方が好きでやり込みたくなってきてるので、
そろそろ、
に専念しよ〜〜〜〜!
おそらく来年から本記事は書いても1日1本は行かないかな 藁