Notice
Recent Posts
Recent Comments
Link
투케이2K
268. (kotlin/코틀린) [유틸 파일] observableSeekBar : SeekBar 시크바 팝업창 호출 본문
[개발 환경 설정]
개발 툴 : AndroidStudio
개발 언어 : Kotlin
[소스 코드]
// ----------------------------------------------------------------------------------
// TODO [SEARCH FAST] : [Observable] : [SeekBar 팝업창 호출 처리 메소드]
// ----------------------------------------------------------------------------------
// TODO [호출 방법 소스 코드]
// ----------------------------------------------------------------------------------
/*
try {
// [팝업창 활성 수행]
C_Ui_View.observableSeekBar(A_Intro@this, "값을 지정해 주세요", "확인", "취소")
.subscribeOn(AndroidSchedulers.mainThread()) // [Observable (생성자) 로직을 IO 스레드에서 실행 : 백그라운드]
.observeOn(Schedulers.io()) // [Observer (관찰자) 로직을 메인 스레드에서 실행]
.subscribe(
{ value ->
S_Log.ltw("================================================")
S_Log.cnt("[" + ACTIVITY_NAME + " >> SeekBar 팝업창 활성 :: onNext]")
S_Log.cnt("-----------------------------------------")
S_Log.cnt("[VALUE :: $value]")
S_Log.lbw("================================================")
},
{ error ->
S_Log.lte("================================================")
S_Log.cnt("[" + ACTIVITY_NAME + " >> SeekBar 팝업창 활성 :: onError]")
S_Log.cnt("-----------------------------------------")
S_Log.cnt("[ERROR :: " + error.message.toString() + "]")
S_Log.lbe("================================================")
}
)
{
}
}
catch (e : Exception) {
e.printStackTrace()
}
*/
// ----------------------------------------------------------------------------------
var seeekData: String = ""
fun observableSeekBar(mContext: Context, title : String, ok: String, no: String): Observable<String> {
// [로직 처리 실시]
return Observable.create { subscriber: ObservableEmitter<String> ->
try {
S_Log.ltd("================================================")
S_Log.cnt("[" + ACTIVITY_NAME + " >> observableSeekBar :: SeekBar 팝업창 호출 수행 실시]")
S_Log.lbd("================================================")
// [변수 초기화]
seeekData = ""
// [UI 생성 실시]
val seekBar = SeekBar(mContext)
seekBar.setPadding(100, 15, 100, 15)
// [시크바 min , max 선언]
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
seekBar.min = 0
}
seekBar.max = 100
// [이벤트 지정 실시]
seekBar.setOnSeekBarChangeListener(object : OnSeekBarChangeListener {
override fun onStopTrackingTouch(seekBar: SeekBar) {}
override fun onStartTrackingTouch(seekBar: SeekBar) {}
override fun onProgressChanged(seekBar: SeekBar, progress: Int, fromUser: Boolean) {
// [변수에 삽입 실시]
seeekData = progress.toString()
}
})
// [팝업창 생성 실시]
Handler(Looper.getMainLooper()).postDelayed({
if (mContext != null) {
// [AlertDialog 팝업창 생성]
AlertDialog.Builder(mContext) //.setTitle(title) //[팝업창 타이틀 지정]
.setTitle(title)
//.setIcon(R.drawable.app_icon) //[팝업창 아이콘 지정]
.setMessage("\n") //[팝업창 내용 지정]
.setView(seekBar)
.setCancelable(false) //[외부 레이아웃 클릭시도 팝업창이 사라지지않게 설정]
.setPositiveButton(ok) { dialog, which ->
// TODO Auto-generated method stub
// -----------------------------------------
// TODO [확인 버튼 클릭 이벤트 처리]
// -----------------------------------------
S_Log.ltd("================================================")
S_Log.cnt("[" + ACTIVITY_NAME + " >> observableSeekBar :: SeekBar 팝업창 호출 [확인] 클릭]")
S_Log.cnt("[선택 값 :: " + seeekData.toString() + "]")
S_Log.lbd("================================================")
// -----------------------------------------
// TODO [리턴 데이터 반환]
// -----------------------------------------
try {
subscriber.onNext(seeekData.toString())
subscriber.onComplete()
} catch (ex: Exception) {
ex.printStackTrace()
}
// -----------------------------------------
}
.setNegativeButton(no) { dialog, which ->
// TODO Auto-generated method stub
// -----------------------------------------
// TODO [취소 버튼 클릭 이벤트 처리]
// -----------------------------------------
S_Log.lte("================================================")
S_Log.cnt("[" + ACTIVITY_NAME + " >> observableSeekBar :: SeekBar 팝업창 호출 [취소] 클릭]")
S_Log.lbe("================================================")
// -----------------------------------------
// TODO [리턴 데이터 반환]
// -----------------------------------------
try {
subscriber.onNext("")
subscriber.onComplete()
} catch (ex: Exception) {
ex.printStackTrace()
}
// -----------------------------------------
}
.show()
}
}, 0)
} catch (e: Exception) {
e.printStackTrace()
S_Log.lte("================================================")
S_Log.cnt("[" + ACTIVITY_NAME + " >> observableSeekBar :: SeekBar 팝업창 호출 [Exception] 확인]")
S_Log.cnt("-----------------------------------------")
S_Log.cnt("[EXCEPTION :: " + e.message.toString() + "]")
S_Log.lbe("================================================")
// ------------------------------------------------------
// TODO [리턴 데이터 반환]
// ------------------------------------------------------
try {
subscriber.onNext("")
subscriber.onComplete()
} catch (ex: Exception) {
ex.printStackTrace()
}
}
}
}
[결과 출력]
반응형
'Kotlin' 카테고리의 다른 글
Comments