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

[아이폰] - 위젯 : UIButton, UISwitch, UIImageView 사용하기 예제

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

○ 위젯 : UIButton, UISwitch, UIImageView 사용하기 예제

 

UIButton

   setImage() - 버튼에 이미지 적용

   setTitle() - 확인 및 취소 버튼 만들 때 그 버튼의 이름


UISwitch

    setOn - true/false 사용하여 스위치 on/off 설정

    isOn - 스위치 현재 상태 읽기


UIImageView

    image - 출력하고자 하는 UIImage 객체 변수

    setContentMode - 부모 뷰 크기에 따라 그 내용을 어떻게 지정할지 결정(UIView 속성)


import UIKit


class ViewController: UIViewController { 

    var isZoom = false

    @IBOutlet weak var imgView: UIImageView! // 이미지 바꾸기 위한 변수 선언

    @IBOutlet weak var btnResize: UIButton! // 변수 선언(확대 <-> 축소 왔다갔다 위해)

    @IBAction func clickButton(_ sender: UIButton) { // 클릭 이벤트 처리(action)

        let scale : CGFloat = 2.0

        var newWidth:CGFloat, newHeight:CGFloat // 그래픽 그릴 때(이미지 확대/축소 시)


        if(isZoom == true) {

            newWidth = imgView.frame.width / scale // 현이미지 사이즈에서 2배 나눈(너비)

            newHeight = imgView.frame.height / scale // 현이미지 사이즈에서 2배 나눈(높이)


            imgView.frame.size = CGSize(width: newWidth, height: newHeight) // 이미지크기 적용

            btnResize.setTitle("확 대", for: .normal) // 버튼 클릭 시 텍스트 변경

            btnResize.setTitleColor(UIColor.blue, for: .normal) // 버튼 클릭 시 색깔 변경

        } else {

            newWidth = imgView.frame.width * scale // 현이미지 사이즈에서 2배 곱한(너비)

            newHeight = imgView.frame.height * scale // 현이미지 사이즈에서 2배 곱한(높이)


            imgView.frame.size = CGSize(width: newWidth, height: newHeight) // 이미지크기 적용

            btnResize.setTitle("축 소", for: .normal) // 버튼 클릭 시 텍스트 변경

            btnResize.setTitleColor(UIColor.red, for: .normal) // 버튼 클릭 시 색깔 변경

        }

        isZoom = !isZoom  // 클릭시 제어변수 바꿔 주겠금

    }


    @IBAction func switchOnoff(_ sender: UISwitch) { // 스위치가 On, Off 일때, 이미지 변경

        if(sender.isOn) { // sender로 받아서 이벤트 처리, _ 는 정보 생략, UISwitch의 isOn 사용

            imgView.image = UIImage(named: "turnOnImage.jpg")  // 이미지 불러와 적용

        } else {

            imgView.image = UIImage(named: "turnOffImage.jpg")

        }

    }


    override func viewDidLoad() {

        super.viewDidLoad()

    }


    override func didReceiveMemoryWarning() {

        super.didReceiveMemoryWarning()

    }

}




저작자표시 (새창열림)

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

[아이폰] - Swift for Windows 사용 시 NSObject 에러날 때 해결법  (0) 2018.10.28
[아이폰] - 배열과 UIButton 사용하기 예제  (0) 2018.10.16
[아이폰] - 뷰 컨트롤러에서 효과주기(폰트, 정렬 등)  (0) 2018.10.16
[아이폰] - 스위프트 상속과 오버라이딩  (0) 2018.10.16
[아이폰] - 스위프트 클래스(Class) 생성 및 초기화  (0) 2018.10.16

댓글()
카테고리
  • 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)
최근 등록 현황
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
달력
지난달
2026.2
다음달
일월화수목금토
1234567
891011121314
15161718192021
22232425262728
태그 구름
  • 정보처리산업기사 필기 정리
  • 안드로이드 intent
  • 정보처리산업기사 요약
  • 안드로이드 카카오 로그인
  • 정보처리기사 실기 정리
  • 카카오 로그인
  • HTML
  • nodejs express
  • jsp
  • 이클립스 mysql 연동
  • 정보처리산업기사 총정리
  • 안드로이드 카카오 로그인 연동
  • 카카오 로그인 연동
  • 소켓
  • 정규화
  • 정보처리산업기사 15년 필기
  • 리눅스
  • 안드로이드
  • 커널 모듈 프로그래밍
  • 데이터베이스
  • 이클립스 디비 연동
  • 자료구조
  • 정보처리산업기사 필기
  • 정보처리산업기사 15년
  • 소켓 프로그래밍
  • 정보처리산업기사 16년 필기
  • 정보처리산업기사 16년
  • 정규형
  • 정보처리산업기사 정리
  • nodejs MySQL 연동하기(Connection Pool)
카운터
전체 방문자
오늘
어제
Skin by M1REACT. Designed by M1STORY.TISTORY.COM. Valid XHTML 1.0 and CSS 3. Copyright ⓒ Riucc's Storage. All rights reserved.

티스토리툴바