質問編集履歴
4
訂正しました!
test
CHANGED
@@ -1 +1 @@
|
|
1
|
-
[swift4]
|
1
|
+
[swift4]プッシュ通知のためにトークン取得について
|
test
CHANGED
@@ -1,12 +1,12 @@
|
|
1
1
|
###前提・実現したいこと
|
2
2
|
|
3
|
-
|
3
|
+
トークンを取得してプッシュ通知を出したいのですがアップルdeveloperの有料登録をしないとできないものですか?
|
4
4
|
|
5
5
|
|
6
6
|
|
7
7
|
###エラーメッセージ
|
8
8
|
|
9
|
-
|
9
|
+
https://i-app-tec.com/ios/apns-device-token.html のサイトを参考に試してみたのですが、App IDsのところで詰まってしまいます
|
10
10
|
|
11
11
|
|
12
12
|
|
3
質問内容を少し変更しました
test
CHANGED
@@ -1 +1 @@
|
|
1
|
-
[swift4]タ
|
1
|
+
[swift4]Alamofireを使ってJSONデータを送信する
|
test
CHANGED
@@ -1,12 +1,12 @@
|
|
1
1
|
###前提・実現したいこと
|
2
2
|
|
3
|
-
タ
|
3
|
+
Alamofireを使ってtextfieldに打ち込まれた文字と位置情報をJSONデータとしてサーバに送信するプログラムが作りたいです
|
4
4
|
|
5
5
|
|
6
6
|
|
7
7
|
###エラーメッセージ
|
8
8
|
|
9
|
-
|
9
|
+
Alamofiremをプログラムにimportするとこまではできたのですが使い方がわかりません、ネットで調べてもよくわからなかったので質問しました
|
10
10
|
|
11
11
|
|
12
12
|
|
@@ -14,80 +14,8 @@
|
|
14
14
|
|
15
15
|
###該当のソースコード
|
16
16
|
|
17
|
-
```swift4
|
17
|
+
``` swift4
|
18
18
|
|
19
|
-
// 時間の表示
|
20
19
|
|
21
|
-
func displayTime(_ time: TimeInterval) {
|
22
|
-
|
23
|
-
let minute = (Int)(fmod((time/60), 60))
|
24
|
-
|
25
|
-
let second = (Int)(fmod(time, 60))
|
26
|
-
|
27
|
-
let msec = (Int)((time - floor(time))*100)
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
timeL.text = String(format: "%02d : %02d : %02d", minute, second, msec)
|
32
|
-
|
33
|
-
}
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
// 時間の計測
|
38
|
-
|
39
|
-
@objc func timerCounter() {
|
40
|
-
|
41
|
-
let currentTime = totalTime + Date().timeIntervalSince(startTime)
|
42
|
-
|
43
|
-
displayTime(currentTime)
|
44
|
-
|
45
|
-
}
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
// タイマーのスタート
|
50
|
-
|
51
|
-
func startTimer() {
|
52
|
-
|
53
|
-
if timer != nil {
|
54
|
-
|
55
|
-
timer.invalidate()
|
56
|
-
|
57
|
-
}
|
58
|
-
|
59
|
-
else {
|
60
|
-
|
61
|
-
startTime = Date();
|
62
|
-
|
63
|
-
}
|
64
|
-
|
65
|
-
timer = Timer.scheduledTimer(
|
66
|
-
|
67
|
-
timeInterval: 0.01,
|
68
|
-
|
69
|
-
target: self,
|
70
|
-
|
71
|
-
selector: #selector(self.timerCounter),
|
72
|
-
|
73
|
-
userInfo: nil,
|
74
|
-
|
75
|
-
repeats: true)
|
76
|
-
|
77
|
-
}
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
// タイマーのリセット
|
82
|
-
|
83
|
-
func resetTimer() {
|
84
|
-
|
85
|
-
startTime = Date();
|
86
|
-
|
87
|
-
totalTime = 0.0
|
88
|
-
|
89
|
-
displayTime(totalTime)
|
90
|
-
|
91
|
-
}
|
92
20
|
|
93
21
|
```
|
2
質問内容を少し変えてみました
test
CHANGED
@@ -1 +1 @@
|
|
1
|
-
[swift4]
|
1
|
+
[swift4]タイマーのリセット
|
test
CHANGED
@@ -1,12 +1,12 @@
|
|
1
1
|
###前提・実現したいこと
|
2
2
|
|
3
|
-
|
3
|
+
タイマーをリセットする関数を作り何かを判定した際に一度リセットしてそこから時間を再計測したいです
|
4
4
|
|
5
5
|
|
6
6
|
|
7
7
|
###エラーメッセージ
|
8
8
|
|
9
|
-
|
9
|
+
一度リセット関数を呼び出すとそこから何度もリセット関数が呼ばれたような挙動になります。
|
10
10
|
|
11
11
|
|
12
12
|
|
@@ -16,49 +16,77 @@
|
|
16
16
|
|
17
17
|
```swift4
|
18
18
|
|
19
|
-
|
19
|
+
// 時間の表示
|
20
20
|
|
21
|
-
|
21
|
+
func displayTime(_ time: TimeInterval) {
|
22
|
+
|
23
|
+
let minute = (Int)(fmod((time/60), 60))
|
24
|
+
|
25
|
+
let second = (Int)(fmod(time, 60))
|
26
|
+
|
27
|
+
let msec = (Int)((time - floor(time))*100)
|
22
28
|
|
23
29
|
|
24
30
|
|
25
|
-
|
31
|
+
timeL.text = String(format: "%02d : %02d : %02d", minute, second, msec)
|
26
32
|
|
27
|
-
|
33
|
+
}
|
28
34
|
|
29
|
-
|
35
|
+
|
30
36
|
|
31
|
-
|
37
|
+
// 時間の計測
|
32
38
|
|
33
|
-
|
39
|
+
@objc func timerCounter() {
|
34
40
|
|
35
|
-
|
41
|
+
let currentTime = totalTime + Date().timeIntervalSince(startTime)
|
36
42
|
|
37
|
-
|
43
|
+
displayTime(currentTime)
|
38
44
|
|
39
|
-
|
45
|
+
}
|
40
46
|
|
47
|
+
|
48
|
+
|
49
|
+
// タイマーのスタート
|
50
|
+
|
51
|
+
func startTimer() {
|
52
|
+
|
41
|
-
|
53
|
+
if timer != nil {
|
54
|
+
|
55
|
+
timer.invalidate()
|
42
56
|
|
43
57
|
}
|
44
58
|
|
45
|
-
|
59
|
+
else {
|
46
60
|
|
47
|
-
|
61
|
+
startTime = Date();
|
48
|
-
|
49
|
-
print("Error (error.localizedDescription)")
|
50
62
|
|
51
63
|
}
|
52
64
|
|
53
|
-
|
65
|
+
timer = Timer.scheduledTimer(
|
54
66
|
|
55
|
-
|
67
|
+
timeInterval: 0.01,
|
56
68
|
|
57
|
-
a
|
69
|
+
target: self,
|
58
70
|
|
59
|
-
|
71
|
+
selector: #selector(self.timerCounter),
|
60
72
|
|
61
|
-
|
73
|
+
userInfo: nil,
|
74
|
+
|
75
|
+
repeats: true)
|
76
|
+
|
77
|
+
}
|
78
|
+
|
79
|
+
|
80
|
+
|
81
|
+
// タイマーのリセット
|
82
|
+
|
83
|
+
func resetTimer() {
|
84
|
+
|
85
|
+
startTime = Date();
|
86
|
+
|
87
|
+
totalTime = 0.0
|
88
|
+
|
89
|
+
displayTime(totalTime)
|
62
90
|
|
63
91
|
}
|
64
92
|
|
1
コードを変えました
test
CHANGED
@@ -1 +1 @@
|
|
1
|
-
[swift4]システム音
|
1
|
+
[swift4]システム音の連続再生・停止
|
test
CHANGED
@@ -6,7 +6,7 @@
|
|
6
6
|
|
7
7
|
###エラーメッセージ
|
8
8
|
|
9
|
-
|
9
|
+
音楽の連続再生、停止はできたのですがシステム音の場合どう書いていいかわかりません
|
10
10
|
|
11
11
|
|
12
12
|
|
@@ -16,76 +16,50 @@
|
|
16
16
|
|
17
17
|
```swift4
|
18
18
|
|
19
|
-
|
19
|
+
override func viewDidLoad() {
|
20
20
|
|
21
|
-
|
21
|
+
super.viewDidLoad()
|
22
22
|
|
23
|
-
|
23
|
+
|
24
24
|
|
25
|
-
ale
|
25
|
+
let audioPath = Bundle.main.path(forResource: "sample", ofType:"mp3")!
|
26
26
|
|
27
|
-
|
27
|
+
let audioUrl = URL(fileURLWithPath: audioPath)
|
28
28
|
|
29
|
-
|
29
|
+
|
30
30
|
|
31
|
-
|
31
|
+
var audioError:NSError?
|
32
32
|
|
33
|
-
|
33
|
+
do {
|
34
34
|
|
35
|
-
|
35
|
+
audioPlayer = try AVAudioPlayer(contentsOf: audioUrl)
|
36
36
|
|
37
|
-
|
37
|
+
} catch let error as NSError {
|
38
38
|
|
39
|
-
|
39
|
+
audioError = error
|
40
40
|
|
41
|
-
})
|
42
|
-
|
43
|
-
)
|
44
|
-
|
45
|
-
self.present(
|
46
|
-
|
47
|
-
alert,
|
48
|
-
|
49
|
-
a
|
41
|
+
audioPlayer = nil
|
50
|
-
|
51
|
-
completion: {
|
52
|
-
|
53
|
-
print("アラートが表示された")
|
54
42
|
|
55
43
|
}
|
56
44
|
|
45
|
+
|
46
|
+
|
47
|
+
if let error = audioError {
|
48
|
+
|
49
|
+
print("Error (error.localizedDescription)")
|
50
|
+
|
57
|
-
|
51
|
+
}
|
58
52
|
|
59
53
|
|
60
54
|
|
61
|
-
|
55
|
+
audioPlayer.delegate = self
|
62
56
|
|
63
|
-
|
57
|
+
audioPlayer.prepareToPlay()
|
64
58
|
|
65
|
-
|
66
|
-
|
67
|
-
if let soundUrl = CFBundleCopyResourceURL(CFBundleGetMainBundle(), nil, nil, nil){
|
68
|
-
|
69
|
-
AudioServicesCreateSystemSoundID(soundUrl, &soundIdRing)
|
70
|
-
|
71
|
-
|
59
|
+
audioPlayer.numberOfLoops = -1
|
72
|
-
|
73
|
-
}
|
74
60
|
|
75
61
|
|
76
62
|
|
77
63
|
}
|
78
64
|
|
79
65
|
```
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
###試したこと
|
84
|
-
|
85
|
-
課題に対してアプローチしたことを記載してください
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
###補足情報(言語/FW/ツール等のバージョンなど)
|
90
|
-
|
91
|
-
より詳細な情報
|