Kotlin
541. (kotlin/코틀린) [간단 소스] 안드로이드 Webview 웹뷰 window open 새창 열기 이벤트 발생 시 Alert 팝업창 표시 및 외부 링크 이동 수행
투케이2K
2025. 1. 26. 12:36
[개발 환경 설정]
개발 툴 : AndroidStudio
개발 언어 : Kotlin
[소스 코드]
// --------------------------------------------------------------------------------------
[개발 및 테스트 환경]
// --------------------------------------------------------------------------------------
- 언어 : Java / Kotlin
- 개발 툴 : AndroidStudio
- 기술 구분 : Webview / Window Open / Alert
// --------------------------------------------------------------------------------------
// --------------------------------------------------------------------------------------
[사전) 필요 설정]
// --------------------------------------------------------------------------------------
[AndroidManifest.xml 파일 필요 퍼미션]
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
[JavaScript 의 window.open 허용]
main_webview!!.settings.javaScriptCanOpenWindowsAutomatically = true
main_webview!!.settings.setSupportMultipleWindows(true) // [새창 띄우기 허용]
// --------------------------------------------------------------------------------------
// --------------------------------------------------------------------------------------
[소스 코드]
// --------------------------------------------------------------------------------------
// -----------------------------------------
// TODO [크롬 클라이언트 설정 실시]
// -----------------------------------------
main_webview!!.webChromeClient = object : WebChromeClient() {
// TODO [웹뷰 [window open] 새창 열기 이벤트 확인]
override fun onCreateWindow(view: WebView, isDialog: Boolean, isUserGesture: Boolean, resultMsg: Message): Boolean {
S_Log._F_(this@A_Webview, "웹뷰 [window open] 새창 열기 이벤트 발생", null)
val mWebViewPop = WebView(view.context)
mWebViewPop.webViewClient = object : WebViewClient() {
//override fun shouldOverrideUrlLoading(view: WebView, url: String): Boolean {
override fun shouldOverrideUrlLoading(view: WebView, request: WebResourceRequest): Boolean {
var url = request.url.toString() // [Get Web Url]
S_Log._F_(this@A_Webview, "shouldOverrideUrlLoading :: 웹뷰 [window open] 새창 열기 주소 확인", arrayOf(
"URL :: $url"
))
// [url 체크 수행 실시]
if (url.contains("http://") || url.contains("https://")) {
// [외부 링크 이동]
//C_MoveApp.goChromeBrowser(this@A_Webview, url)
// [Alert 팝업창 표시]
C_Ui_View.observableAlert(this@A_Webview, R.drawable.loading_bg, "알 림 (Window Open)", "\n" + url + " 주소 이동 이벤트가 감지 되었습니다. 외부 링크 이동 하시겠습니까?" + "\n", "이동", "취소")
.subscribeOn(AndroidSchedulers.mainThread()) // [Observable (생성자) 로직을 IO 스레드에서 실행 : 백그라운드]
.observeOn(Schedulers.io()) // [Observer (관찰자) 로직을 메인 스레드에서 실행]
.subscribe(
{ value ->
if (value == true){
// [외부 링크 이동]
C_MoveApp.goChromeBrowser(this@A_Webview, url)
}
},
{ error ->
}
)
{
}
}
return true // [로직 종료]
}
}
val transport = resultMsg.obj as WebViewTransport
transport.webView = mWebViewPop
resultMsg.sendToTarget()
// -------------------------------------------------------------
return true // [로직 종료]
// -------------------------------------------------------------
}
// TODO [웹뷰 [window close] 새창 닫기 이벤트 확인]
override fun onCloseWindow(window: WebView?) {
S_Log._F_(this@A_Webview, "웹뷰 [window close] 새창 닫기 이벤트 확인", null)
try {
//window.setVisibility(View.GONE);
//window.destroy();
} catch (e: Exception) {
}
super.onCloseWindow(window)
}
}
// --------------------------------------------------------------------------------------
// --------------------------------------------------------------------------------------
[참고 사이트]
// --------------------------------------------------------------------------------------
// [안드로이드 웹뷰 유틸 파일]
https://blog.naver.com/kkh0977/222680670897
[안드로이드 ( android ) 웹뷰 window open 새창 열기 이벤트 발생 시 Alert 팝업창 표시, 외부링크 이동 개선 요청]
https://blog.naver.com/kkh0977/223738898023
// --------------------------------------------------------------------------------------
반응형