일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
- MacOS
- rxswift
- SwiftUI
- Session
- darkmode
- geofencing
- 개발자
- IOS
- JPA
- 한글
- Git
- UIButton
- appstore
- iOS16
- Swift
- Notification
- github
- window
- view
- FLUTTER
- Firebase
- Apple
- Code
- Realm
- 이미지
- Xcode
- 웹뷰
- mac
- Archive
- error
- Today
- Total
목록UIButton (4)
EEYatHo 앱 깎는 이야기

Swift의 UIButton에 Label과 Image를 모두 넣을 경우, 아래와같이, image - Label 순서로 그려집니다. 이 구조가 맘에 안들경우, myButton.imageEdgeInsets = UIEdgeInsets(top: 0, left: 20, bottom: 0, right: 0) myButton.titleEdgeInsets = UIEdgeInsets(top: 0, left: 0, bottom: 0, right: 20) 이런식으로 titleEdgeInsets 와 imageEdgeInsets를 일일히 조절하는 방법도 있지만, Label과 Image의 순서만 바꿔야 한다면, myButton.semanticContentAttribute = .forceRightToLeft 이렇게 간단하게 할 수..
class MyCell: UITableViewCell { ... func initFunc() { ... myButton.addTarget(self, action: #selector(myFunc(_:)), for: .touchUpInside) ... } @objc myFunc(sender: UIButton) { ... } ... } 이런식으로 셀 안에서 addTarget으로 셀 안에 있는 @objc func을 연결해줘봤자, .touchUpInside 이벤트를 받고, 처리하는 객체는 Cell 보다 상위에 있는 뷰컨트롤러가 합니다. 그래서 self는 상위에 있는 뷰컨으로 바뀌어야 할 것이며, @objc함수로 뷰컨에다가 선언해야합니다. 그러면 셀 안에 굳이 VC를 전달하고, 다시 함수를 참조해야하는데, 그것보다..
var myButton = UIButton(type: .system) ... myButton.setTitle("text", for: .normal) ... myButton.setTitle("text2", for: .normal) 위와 같이 .system 타입으로 선언한 버튼에, 두번째 setTitle을 하게 되면, 버튼의 텍스트들이 천천히 사라졌다가 나타나는 애니메이션이 적용됩니다. 이런 애니메이션을 원하지 않을 경우, var myButton = UIButton(type: .system) ... myButton.setTitle("text", for: .normal) ... UIView.setAnimationsEnabled(false) myButton.setTitle("text2", for: .normal..

[요약] 버튼.adjustsImageWhenHighlighted = false 그냥 직관적으로는, setImage(이미지, for: .Highlighted) 하면 당연히 될 줄 알았는데.. 그런데 하얀색이 포함된 이미지를 쓸 일이 생겨서 setImage로 했더니, 이미지의 하얀 부분은 회색으로 바뀌는겁니다. 안이쁘게..🤔 그래서 찾아봄 버튼.adjustsImageWhenHighlighted = false 하믄 됨 👍 IB에는 저~아래, Drawing 탭에 있돠 관련 애플 개발자 문서