-
[iOS] UI components 조사iOS 2022. 9. 21. 14:40
UI components 속성
- Label
- 정보 텍스트의 한 줄 이상을 표시하는 보기.
- 텍스트의 글꼴, 텍스트 색상, 정렬, 강조 표시 및 음영을 제어 가능.
- Button
- 사용자 상호 작용에 대한 응답으로 사용자 지정 코드를 실행하는 컨트롤.
- 버튼의 제목, 이미지 및 기타 모양 속성을 설정 가능. 각 버튼 상태에 대해 다른 모양을 지정 가능.
- Segmented Control
- 여러 세그먼트로 구성된 수평 컨트롤로, 각 세그먼트는 개별 버튼으로 작동.
- 단일 또는 다중 선택 또는 명령 목록을 나타낼 수 있음, 각 세그먼트는 텍스트 또는 이미지를 표시 할 수 있지만 둘 다 표시는 불가능.
- Text Field
- 사용자가 상호 작용할 수 있는 텍스트 필드를 표시.
- 사용자가 텍스트 필드에 작성할 수 있음.
- Slider
- 값의 제한된 선형 범위에서 값을 선택하기 위한 컨트롤.
- 값 범위를 나타내는 트랙이라는 가로 막대를 표시. 현재 값은 표시기 또는 엄지 손가락의 위치로 표시됨.사용자는 트랙을 따라 엄지 손가락을 밀어 값을 선택.
- Switch
- 선행 레이블과 후행 스위치를 표시하는 토글 스타일.
- 컨트롤을 탭하면 상태를 전환.
- Activity Indicator View
- 작업이 진행 중임을 나타내는 보기.
- 완료상태를 알 수 없는 작업에 대한 처리를 나타내는 데 사용.
- Progress View
- 작업 완료를 향한 진행 상황을 보여주는 보기.
- 긴 작업이 진행 중임을 나타내며 완료된 작업의 백분율을 나타냄.
- Page Control
- 수평의 연속되는 점으로 표시되는 제어.
- 열려있는 각 페이지에 대해 점을 표시하여 응용 프로그램에서 열려있는 페이지 수를 나타냄. 현재 본 페이지에 해당하는 점이 강조 표시.
- Stepper
- 값을 증가하거나 감소시키는 제어.
- 레이블 또는 텍스트 필드와 결합.
- Horizontal Stack View
- 수평 또는 수직 뷰 스택을 만드는데 필요한 제약 조건을 생성하고 관리.
- Vertical Stack View
- 수평 또는 수직 뷰 스택을 만드는데 필요한 제약 조건을 생성하고 관리.
- Table View
- 테이블 타입으로 데이터를 표시할 수 있는 뷰.
- 테이블 뷰의 각 행은 UITalbleViewCell 개체. 사용자는 테이블 셀을 삽입, 삭제 및 재정렬하여 테이블을 편집할 수 있음.
- Table View Cell
- 테이블 뷰에서 셀의 특성 및 동작을 정의.
- 테이블 셀의 선택한 상태 모양을 설정하고, 편집 기능을 지원.
- Image View
- 인터페이스에서 단일 이미지 또는 일련의 애니메이션를 표시.
- 이미지를 화면에 표시하고 싶을 때 사용.
- Collection View
- 커스텀한 레이아웃을 사용하여 정렬된 데이터 항목 모음을 관리. 컬렉션 뷰의 각 셀은 UICollectionViewCell 객체.
- 셀을 섹션으로 그룹화 할 수 있으며 섹션과 셀을 선택적으로 보조 보기를 가질 수 있음.
- Collection View Cell
- 컬렉션 뷰에서 하나의 셀을 나타내는 단일 뷰. 모양을 제공하려면 Label 및 Image View 와 같은 하위 View로 채움.
- Collection Reusable View
- Collection View에서 재사용 가능한 View의 특성 및 동작을 정의
- Text View
- 응용 프로그램별 방식으로 입력을 처리. 사용자가 텍스트 보기를 누르면 키보드가 나타나고 Return을 누르면 키보드가 사라짐.
Text Field: 한줄로만 작성 가능
Text View: 여러줄로 작성 가능하고 텍스트가 길어지면 자동으로 스크롤 기능을 제공- Scroll View
- 응용 프로그램 창 크기보다 큰 콘텐츠를 표시하는 메커니즘을 제공하며 사용자가 스와핑 제스처를 통해 해당 콘텐츠 내에서 스크롤할 수 있도록 함.
- Date Picker
- 날짜와 시간을 선택할 수 있도록 여러개의 회전 바퀴를 사용.
- 예시로는 시계 응용프로그램의 타이머가 있음.
- 사람들이 선택할 수 있는 고유한 값의 스크롤 가능한 목록을 하나 이상 표시.
- Visual Effect View with Blur
- 다른 View 뒤에 사용자 정의 가능한 혼합효과를 제공.
- Blur 처리할때 사용.
- Visual Effect View with Blur and Vibrancy
- Blur 배경을 제공하고 포함된 뷰를 생생한 효과로 렌더링.
- Map Kit View
- 지도 애플리케이션에서 제공화는 것과 유사한 내장형 맵 인터페이스를 제공
- 지정된 좌표에 지도를 가운데로 배치하고,표시할 영역의 크기를 지정하며, 지도에 사용자 지정 정보를 주석으로 달 수 있음.
- 클래스를 현재 상태로 사용하여 지도 정보를 표시하고 프로그램에서 지도 내용을 조작가능
- MetalKit View
- 3D Model, Texture등 Metal Drawing 어플리케이션을 만드는데 필요한 노력을 단순화함.
- MTKView 개체를 사용하면 응용 프로그램을 대신하여 MTLRenderPassDescripot(??) 개체 및 관련 렌더 타겟 첨부파일을 편리하게 관리할 수 있고, 내용을 업데이트해야 할 때 보기를 간단히 그릴 수 있음.
- GLKit View
- OpenGL(실리콘 그래픽스사에서 만든 2차원 및 3차원 그래픽스 표준 API 규격으로, 프로그래밍 언어 간 플랫폼 간의 교차 응용 프로그래밍을 지원)을 활용한 어플리케이션을 만드는데 필요한 노력을 단순화.
- 응용 프로그램을 대신하여 프레임 버퍼 object를 직접 관리.
- SceneKit View
- SceneKit 프레임워크를 사용하여 3D장면을 표시할 수 있음.
- 응용 프로그램에서 3D 장면을 쉽게 로드, 조작 및 렌더링 할 수 있음.
- SpriteKit View
- SpriteKit 프레임워크를 사용하여 2D장면을 표시할 수 있음.
- 응용 프로그램에서 2D 장면을 쉽게 로드, 조작 및 렌더링 할 수 있음.
ARKit : iOS에서 증강현실을 가능하게 해주는 프레임워크
- ARKit SceneKit View
- ARkit 및 SceneKit 프레임워크를 이용해서 카메라 배경에 3D 장면을 표시 할 수 있음.
- 응용프로그램에서 3D 장면을 쉽게 로드, 조작 및 렌더링 할 수 있음.
- ARKit SpriteKit View
- ARkit 및 SpriteKit 사용할 수 있게 허용해줌.
- 응용프로그램에서도 장면을 쉽게 로드, 조작 및 렌더링 할 수 있음.
- Web View
- 포함된 HTML 및 웹 사이트와 같은 풍부한 웹 콘텐츠를 앱 내에서 직접 로드하고 표시
ex) Mail은 Web View를 사용하여 메시지에 HTML 콘텐츠를 표시
- 4WebKit View
- 웹 콘텐츠를 삽입하고 보여줄 수 있음.
- 콘텐츠 탐색을 활성화함.
- Reality AR View
- RealityKit 프레임워크를 사용하여 3D 대화형 AR장면을 표시할 수 있음.
- 이 기능을 사용하면 응용프로그램에서 3D AR 콘텐츠를 쉽게 로드, 조작 및 렌더링할 수 있음.
- View
- 뷰 계층 구조에서 부모의 사각형 영역 내에서 그리기, 하위 뷰 레이아웃 및 이벤트 처리를 위한 구조를 제공.
- Container View
- 하위 뷰 컨트롤러를 호스팅하기 위해 뷰 컨트롤러의 뷰 계층 구조 내에서 영역을 정의.
- 앱 화면 상단에 탐색 표시줄이 나타나 콘텐츠 계층 구조를 탐색.
- 화면 제목을 표시할 수 있는 자연스러운 장소를 제공하여 사람들이 앱이나 게임에서 방향을 잡는 데 도움이 되며 화면 콘텐츠에 영향을 주는 컨트롤을 포함.
- Toolbar
- 화면 하단에 Toolbar Item을 표시하는 매커니즘을 제공하고 도구모음 항목(UIToolbarItem instance)의 표시 및 선택을 지원.
- 도구 모음을 사용하면 현재 보기와 관련된 작업을 수행하는 자주 사용하는 명령과 컨트롤에 편리하게 액세스할 수 있음.
- UIToolbarDelegate를 사용하여 toolbar item에 대한 사용자 지정 보기를 지정.
- 플랫폼에 따라 도구 모음이 다르게 보이고 작동할 수 있음.
- Tab Bar
- 앱에서 보기, 하위 작업이나 모드를 선택하기 위한 막대를 표시.
- 막대 항목을 사용하여 동일한 보기에서 상호 배타적인 콘텐츠 창 사이를 탐색.
- 탭 막대는 보기가 제공하는 다양한 유형의 정보 또는 기능을 이해하는 데 도움이 됨.
- 각 섹션 내에서 현재 탐색 상태를 유지하면서 사람들이 보기의 섹션 간에 빠르게 전환할 수 있음.
- Search Bar
- 검색 아이콘이 포함된 편집 가능한 검색 표시줄.
- return을 누르면 대상 객체에 작업메시지를 보냄.
- 입력한 특정 용어에 대한 콘텐츠 컬렉션을 검색가능.
- 종종 검색 버튼, 지우기 버튼 및 선택적 자리 표시자 텍스트를 표시하는 편집 가능한 텍스트 필드.
- 플랫폼에 따라 검색 텍스트 필드는 토큰을 사용하여 사람들이 입력하는 검색어를 나타내거나 사람들이 필터로 사용할 수 있는 앱 정의 항목을 나타낼 수 있음.
- macOS의 메인 메뉴로 사용할 기본 메뉴 및 command 집합을 포함.
- 인터페이스를 복잡하게 만들지 않고 화면 항목과 직접 관련된 기능에 액세스할 수 있음.
- 메뉴의 하위 항목을 표시하도록 구성된 메뉴.
- View Controller
- 도구 모음, 탐색 모음 및 응용프로그램 뷰에 대한 뷰 관리 기능을 제공.
- UIViewController 클래스는 장치 방향이 변경될 때 회전 보기를 지원.
- Storyboard Reference
- 스토리보드 참조를 통해 스토리보드를 여러 파일로 팩토링할 수 있음.
- 플레이스홀더에 연결된 Segue는 한 스토리보드에서 다른 스토리보드로 전활할 수 있음.
- 뷰 컨트롤러의 스택과 내비게이션바를 관리할 수 있음.
- 뷰 컨트롤러를 스택에 밀어넣었다가 빼면 네비게이션 컨트롤러가 네비게이션 바를 업데이트하고 적절하게 보기를 수행.
- Table View Controller
- 올바른 차원과 사이즈 조절이 가능한 마스크를 통해 인스턴스를 생성하고 tableView를 관리.
- 테이블, 컬렉션, 이미지 및 사용자 지정 보기를 비롯한 다양한 구성 요소를 포함할 수 있는 여러 인접 콘텐츠 창의 프레젠테이션을 관리
- Collection View Controller
- UICollectionView를 관리하며, 올바른 치수와 크기 조정 mask를 사용하여 인스턴스를 자동으로 생성.
- Collection View의 위임자 및 데이터 원본으로 작동.
- Tab Bar Controller
- 각각 탭 표시줄 항목을 나타내는 뷰 컨트롤러 세트를 관리.
- 뷰 컨트롤러는 탭 바 아이템에 대한 정보를 제공하고 아이템을 선택할때 표시할 view를 제공.
- Split View Controller
- 스플릿 뷰 컨트롤러는 마스터 뷰 컨트롤러 (가끔씩 목록)가 하위 뷰 컨트롤러에서 변경을 시작하는 마스터 세부 인터페이스를 만드는데 사용.
Split View
- 테이블, 컬렉션, 이미지 및 사용자 지정 보기를 비롯한 다양한 구성 요소를 포함할 수 있는 여러 인접 콘텐츠 창의 프레젠테이션을 관리
[출처]
https://velog.io/@rlawnstn01023/UIKitUI-component
[Xcode]UI component
스토리보드 컴포넌트에 대한 설명
velog.io
https://developer.apple.com/design/human-interface-guidelines/components/all-components
All components - Components - Human Interface Guidelines - Design - Apple Developer
Split views A split view manages the presentation of multiple adjacent panes of content, each of which can contain a variety of components, including tables, collections, images, and custom views. ios ipados macos tvos side by side sidebar
developer.apple.com
'iOS' 카테고리의 다른 글
[iOS] 전화 기본앱 만들기 (0) 2022.09.29 [iOS] 2주차 세미나 정리 (0) 2022.09.27 [iOS] AutoLayout 개념 & 속성 (0) 2022.09.21 [iOS] AppProject 속성 (1) 2022.09.21 [iOS] info.plist 속성 (0) 2022.09.21