Riucc's Storage
RSS
태그
관리
쓰기
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
Riucc's Storage

[아이폰] - 알림창 띄우기(AlertController)

아이폰|2018. 12. 24. 15:15
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

○ 알림창 띄우기(AlertController) 

 


// 전구 켜고 끄고 삭제하기 경고창 띄우기 

class ViewController: UIViewController {

    // 변수 선언(변수 + let 이용 이미지 적용)

    let imgOn : UIImage = UIImage(named: "turnOn.png")!

    let imgOff : UIImage = UIImage(named: "turnOff.png")!

    let imgRemove : UIImage = UIImage(named: "turnX.png")!

    var isLampOn : Bool = true // 제어하기 위한(Bool)

    @IBOutlet weak var lampImg: UIImageView!


    @IBAction func btnLampOn(_ sender: UIButton) {

        if(isLampOn == true){

            let lampOnAlert = UIAlertController(title: "경고", message : "현재 On 상태입니다", preferredStyle: UIAlertControllerStyle.alert) // 경고창을 만듬

            let onAction = UIAlertAction(title: "네 알겠습니다", style: UIAlertActionStyle.default, handler: nil) // 경고창에 붙일 액션을 만든(네, 아니오 등)

            lampOnAlert.addAction(onAction) // 경고창에 만든 액션을 붙인다

            present(lampOnAlert, animated: true, completion: nil) // present 를 이용해서 만든 경고창을 붙여준다(표현)

        } else {

            lampImg.image = imgOn

            isLampOn = true

        }

    }

     @IBAction func btnLampOff(_ sender: UIButton) {

        if(isLampOn == true){

            let lampOffAlert = UIAlertController(title: "램프 끄기", message : "램프를 끄시겠습니까?", preferredStyle: UIAlertControllerStyle.alert)

            let offAction = UIAlertAction(title: "네", style: UIAlertActionStyle.default, handler: {

                ACTION in self.lampImg.image = self.imgOff // 핸들러로 lampImg 이미지 변경(self 붙여줘야 핸들러에선), { 익명함수이다 }

                self.isLampOn = false

            })

            let cancelAction = UIAlertAction(title: "아니요", style: UIAlertActionStyle.default, handler: nil) // 핸들러 nil 로 그냥 닫기 효과 같은

            lampOffAlert.addAction(offAction) // 경고창에 만든 액션을 붙인다

            lampOffAlert.addAction(cancelAction) // 경고창에 만든 액션을 붙인다

            present(lampOffAlert, animated: true, completion: nil)

        }

    }


    @IBAction func btnLampRemove(_ sender: UIButton) {

        let lampRemoveAlert = UIAlertController(title: "램프 제거", message: "램프를 제거하시겠습니까?", preferredStyle: UIAlertControllerStyle.alert)

        let offAction = UIAlertAction(title: "아니오 끕니다", style: UIAlertActionStyle.default, handler: {

            ACTION in self.lampImg.image = self.imgOff

            self.isLampOn = false

        })

        let onAction = UIAlertAction(title: "아니오 켭니다", style: UIAlertActionStyle.default, handler: {

            ACTION in self.lampImg.image = self.imgOn

            self.isLampOn = true

        })

        let removeAction = UIAlertAction(title: "네 제거합니다", style: UIAlertActionStyle.destructive, handler: {

            ACTION in self.lampImg.image = self.imgRemove

            self.isLampOn = false

        })

        lampRemoveAlert.addAction(offAction)

        lampRemoveAlert.addAction(onAction)

        lampRemoveAlert.addAction(removeAction)

        present(lampRemoveAlert, animated: true, completion: nil)

    }

}


저작자표시 (새창열림)

'아이폰' 카테고리의 다른 글

[아이폰] - 탭 바(Tab Bar)  (0) 2018.12.24
[아이폰] - 뷰컨트롤러 데이터 이동(prepare)  (0) 2018.12.24
[아이폰] - 피커뷰(PickerView) 이미지 데이터 처리  (0) 2018.12.24
[아이폰] - 피커뷰(PickerView) 데이터 처리  (0) 2018.12.24
[아이폰] - 데이트피커(DatePicker) 이용한 현재시간과 선택시간 이벤트  (0) 2018.12.24

댓글()
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
최근 등록 현황
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
달력
지난달
2025.5
다음달
일월화수목금토
123
45678910
11121314151617
18192021222324
25262728293031
태그 구름
  • 정보처리산업기사 요약
  • 정보처리산업기사 15년 필기
  • 안드로이드
  • 정보처리산업기사 15년
  • 카카오 로그인
  • 소켓
  • 카카오 로그인 연동
  • 안드로이드 카카오 로그인 연동
  • 이클립스 디비 연동
  • 소켓 프로그래밍
  • 정보처리산업기사 총정리
  • 정보처리산업기사 16년
  • 이클립스 mysql 연동
  • 데이터베이스
  • 커널 모듈 프로그래밍
  • nodejs MySQL 연동하기(Connection Pool)
  • jsp
  • 자료구조
  • 리눅스
  • nodejs express
  • 안드로이드 intent
  • HTML
  • 정보처리산업기사 정리
  • 정보처리기사 실기 정리
  • 정규형
  • 정보처리산업기사 16년 필기
  • 정규화
  • 정보처리산업기사 필기
  • 정보처리산업기사 필기 정리
  • 안드로이드 카카오 로그인
카운터
전체 방문자
오늘
어제
Skin by M1REACT. Designed by M1STORY.TISTORY.COM. Valid XHTML 1.0 and CSS 3. Copyright ⓒ Riucc's Storage. All rights reserved.

티스토리툴바