브라우저 지원

Patrick Kettner
Patrick Kettner

맞춤 탭은 앱 내에서 직접 맞춤설정된 브라우저 환경을 만들 수 있는 훌륭한 옵션이지만, 단일 탭이 아닙니다. 인텐트 시스템을 기반으로 구축된 맞춤 탭은 최종 사용자가 선호하는 브라우저로 전송되는 구성 가능한 옵션 요청의 모음입니다. 다양한 옵션을 구현하는 것은 각 브라우저의 책임입니다. 맞춤 탭 기능의 사용 가능 여부는 구현 차이로 인해 Android 브라우저마다 다를 수 있습니다.

다음은 Android 생태계의 일부 브라우저를 비교한 것입니다. Android의 대다수 브라우저는 일정 수준의 지원을 제공합니다. 표에 나와 있는 표에 모든 내용이 나와 있는 것은 아니지만 표시될 수 있는 지원 수준을 보여줍니다. 앱을 사용하는 사용자의 기본 브라우저를 조사하고 방어적으로 코딩해야 합니다.

CustomTabsIntent.Builder

CustomTabsIntent.Builder는 맞춤 탭을 만듭니다. 아래에 나열된 기본 제공 메서드 모음을 통해 맞춤 탭이 앱과 최대한 매끄럽게 어우러지도록 다양한 방법으로 맞춤 탭을 구성할 수 있습니다.

addDefaultShareMenuItem()

addDefaultShareMenuItem()은 맞춤 탭 툴바에 기본 공유 버튼을 추가하여 사용자가 기기의 다양한 앱을 통해 현재 웹페이지를 공유할 수 있도록 합니다.

addMenuItem()

메뉴 항목을 추가합니다.

왼쪽은 addMenuItem()을 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화입니다.

addToolbarItem()

맞춤 탭에 작업 버튼을 추가합니다. 이 메서드를 통해 여러 버튼을 추가할 수 있습니다.

enableUrlBarHiding()

사용자가 페이지에서 아래로 스크롤할 때 URL 표시줄을 숨기도록 설정합니다.

setActionButton()

기본 색조 조정 동작으로 툴바에 표시되는 작업 버튼을 설정합니다.

왼쪽은 setActionButton()()을 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화

setCloseButtonIcon()

툴바에 표시되는 맞춤 닫기 버튼을 설정합니다.

왼쪽은 setCloseButtonIcon()을 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화

setCloseButtonPosition()

맞춤 탭의 닫기 버튼 아이콘을 설정합니다.

왼쪽은 setCloseButtonPosition()을 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화

setColorScheme()

맞춤 탭의 사용자 인터페이스에 적용되어야 하는 색 구성표를 설정합니다.

왼쪽에는 setColorScheme()을 사용하는 앱을 보여주는 휴대전화, 오른쪽에는 API가 없는 별도의 휴대전화

setColorSchemeParams()

맞춤 탭의 사용자 인터페이스에 적용되어야 하는 색 구성표를 설정합니다.

왼쪽은 setColorSchemeParams()를 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화

setDefaultColorSchemeParams()

지정된 색 구성표에 CustomTabColorSchemeParams()를 설정합니다. 이렇게 하면 밝은 구성표와 어두운 구성표에 서로 다른 두 가지 툴바 색상을 지정할 수 있습니다.

왼쪽은 setDefaultColorSchemeParams()를 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화

setDefaultShareMenuItemEnabled()

기본 공유 항목을 메뉴에 추가할지 여부를 설정합니다.

setExitAnimations()

모든 종료 애니메이션을 설정합니다.

setInitialActivityHeightPx()

기본 크기 조절 동작으로 맞춤 탭 활동의 초기 높이를 픽셀 단위로 설정합니다. 맞춤 탭이 하단 시트처럼 작동합니다. 이를 부분적인 맞춤 탭이라고도 합니다.

왼쪽은 setInitialActivityHeightPx()를 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화

setNavigationBarColor()

탐색 메뉴 색상을 설정합니다. L 미만의 API 버전에는 영향을 미치지 않습니다.

setNavigationBarDividerColor()

setSecondaryToolbarColor()

보조 툴바의 색상을 설정합니다.

setShareState()

맞춤 탭에 적용해야 하는 공유 상태를 설정합니다.

왼쪽은 setShareState()를 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화

setShowTitle()

맞춤 탭에 제목을 표시할지 여부를 설정합니다.

왼쪽은 setShowTitle()을 사용하는 앱을 보여주는 휴대전화, 오른쪽은 API가 없는 별도의 휴대전화

setStartAnimations()

시작 애니메이션을 설정합니다.

setToolbarColor()

툴바 색상을 설정합니다. Android L 이상에서는 상태 표시줄에도 이 색상이 적용됩니다.

setToolbarCornerRadiusDp()

툴바의 상단 모서리 반경을 dp 단위로 설정합니다.

setUrlBarHidingEnabled()

사용자가 페이지에서 아래로 스크롤할 때 URL 표시줄을 숨길지 여부를 설정합니다.

CustomTabsClient

CustomTabsClientCustomTabsService와 통신하고 여기서 CustomTabsSession을 만드는 선택적 클래스입니다.

준비()

브라우저 프로세스를 준비합니다.

CustomTabsSession

CustomTabsSessionCustomTabsIntent.Builder() 인스턴스에 제공할 수 있는 선택적 클래스입니다. 이 클래스를 사용하면 이 클래스를 사용하여 맞춤 탭과의 통신을 처리할 수 있습니다.

setEngagementSignalsCallback()

탭 내에서 사용자의 웹페이지 참여와 관련된 이벤트의 콜백을 수신하도록 EngagementSignalsCallback를 설정합니다.

isEngagementSignalsApiAvailable()

Engagement Signals API를 사용할 수 있는지 여부를 반환합니다. Engagement Signals API의 사용 가능 여부는 런타임에 변경될 수 있습니다.

MayLaunchUrl()

브라우저에 향후 URL로 이동할 가능성이 있음을 알립니다. 가능성이 가장 높은 URL을 먼저 지정해야 합니다. 가능한 다른 URL의 목록을 제공할 수도 있습니다. 첫 번째 우선순위보다 가능성이 낮은 것으로 취급되며 낮은 우선순위로 정렬해야 합니다. 이러한 추가 URL은 무시해도 됩니다. 이 메서드에 대한 이전의 모든 호출 우선순위가 낮아집니다.