투케이2K

302. (kotlin/코틀린) [유틸 파일] observableQrImage : QR (큐알) ImageView 팝업창 호출 수행 본문

Kotlin

302. (kotlin/코틀린) [유틸 파일] observableQrImage : QR (큐알) ImageView 팝업창 호출 수행

투케이2K 2023. 5. 17. 19:36

[개발 환경 설정]

개발 툴 : AndroidStudio

개발 언어 : Kotlin

 

[소스 코드]

 

        // ----------------------------------------------------------------------------------
        // TODO [SEARCH FAST] : [Observable] : [QR ImageView 팝업창 호출 처리 메소드]
        // ----------------------------------------------------------------------------------
        // TODO [호출 방법 소스 코드]
        // ----------------------------------------------------------------------------------
        /*
        try {

            // [팝업창 활성 수행]
            C_Ui_View.observableQrImage(A_Intro@this, "알림", "hello", "확인")
                .subscribeOn(AndroidSchedulers.mainThread()) // [Observable (생성자) 로직을 IO 스레드에서 실행 : 백그라운드]
                .observeOn(Schedulers.io()) // [Observer (관찰자) 로직을 메인 스레드에서 실행]
                .subscribe(
                    { value ->
                        S_Log.ltw("================================================")
                        S_Log.cnt("[" + ACTIVITY_NAME + " >> QR ImageView 팝업창 활성 :: onNext]")
                        S_Log.cnt("-----------------------------------------")
                        S_Log.cnt("[VALUE :: $value]")
                        S_Log.lbw("================================================")
                    },
                    { error ->
                        S_Log.lte("================================================")
                        S_Log.cnt("[" + ACTIVITY_NAME + " >> QR ImageView 팝업창 활성 :: onError]")
                        S_Log.cnt("-----------------------------------------")
                        S_Log.cnt("[ERROR :: " + error.message.toString() + "]")
                        S_Log.lbe("================================================")
                    }
                )
                {
                }

        }
        catch (e : Exception) {
            e.printStackTrace()
        }
        */
        // ----------------------------------------------------------------------------------
        fun observableQrImage(mContext: Context, title: String, qrData: String, ok: String): Observable<String> {

            // [로직 처리 실시]
            return Observable.create { subscriber: ObservableEmitter<String> ->

                /**
                 * ------------------------------------------------------------------
                 * [의존성 부여 필요]
                 * ------------------------------------------------------------------
                 * implementation 'com.github.kenglxn.QRGen:android:2.6.0'
                 * implementation 'com.journeyapps:zxing-android-embedded:3.5.0'
                 * implementation "com.google.zxing:core:3.3.0"
                 * ------------------------------------------------------------------
                 */

                try {
                    // ===============================================================
                    S_Log._D_("QR 표시 ImageView 팝업창 호출 수행 실시", null)
                    // ===============================================================


                    // [비트맵 생성 실시]
                    val display = (mContext!!.getSystemService(Context.WINDOW_SERVICE) as WindowManager).defaultDisplay
                    val outMetrics = DisplayMetrics()
                    display.getMetrics(outMetrics)
                    val density = mContext.resources.displayMetrics.density

                    val qrWidth = outMetrics.widthPixels.toFloat() // TODO [QR 생성 데이터]

                    val dpHeight = outMetrics.heightPixels / density // TODO [팝업창 사이즈]
                    val dpWidth = outMetrics.widthPixels / density // TODO [팝업창 사이즈]

                    val multiFormatWriter = MultiFormatWriter()
                    val bitMatrix = multiFormatWriter.encode(qrData, BarcodeFormat.QR_CODE, qrWidth.toInt(), qrWidth.toInt())
                    val barcodeEncoder = BarcodeEncoder()
                    val bitmap = barcodeEncoder.createBitmap(bitMatrix)


                    // [UI 생성 실시]
                    val imageView = ImageView(mContext)
                    //imageView.setPadding(5,5,5,5);


                    // [이미지 뷰에 비트맵 지정]
                    imageView.setImageBitmap(bitmap)
                    imageView.scaleType = ImageView.ScaleType.FIT_XY


                    // [팝업창 생성 실시]
                    Handler(Looper.getMainLooper()).postDelayed({
                        if (mContext != null) {

                            // [AlertDialog 팝업창 생성]
                            val dialog = AlertDialog.Builder(mContext)
                                .setTitle(title) //[팝업창 타이틀 지정]
                                //.setIcon(R.drawable.app_icon) //[팝업창 아이콘 지정]
                                //.setMessage("\n") //[팝업창 내용 지정]
                                .setView(imageView)
                                .setCancelable(false) //[외부 레이아웃 클릭시도 팝업창이 사라지지않게 설정]
                                .setPositiveButton(ok) { dialog, which ->
                                    // TODO Auto-generated method stub
                                    // -----------------------------------------
                                    // TODO [확인 버튼 클릭 이벤트 처리]
                                    // -----------------------------------------
                                    S_Log._D_("QR 표시 ImageView 팝업창 호출 [확인] 클릭", null)
                                    // -----------------------------------------


                                    // -----------------------------------------
                                    // TODO [리턴 데이터 반환]
                                    // -----------------------------------------
                                    try {
                                        subscriber.onNext(ok)
                                        subscriber.onComplete()
                                    } catch (ex: Exception) {
                                        ex.printStackTrace()
                                    }
                                    // -----------------------------------------
                                }
                                .show()


                            // [팝업창 레이아웃 사이즈 변경]
                            //*
                            val lp = WindowManager.LayoutParams()
                            val window = dialog.window
                            lp.copyFrom(window!!.attributes)

                            //lp.width = WindowManager.LayoutParams.MATCH_PARENT;
                            //lp.height = WindowManager.LayoutParams.MATCH_PARENT;

                            //lp.width =  (int)TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 350, mContext.getResources().getDisplayMetrics());
                            //lp.height = (int)TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 350, mContext.getResources().getDisplayMetrics());
                            val dpWidthValue = dpWidth.toInt()
                            val dpHeightValue = dpHeight.toInt()

                            // ===============================================================
                            S_Log._W_("QR 표시 ImageView 팝업창 사이즈 확인", arrayOf(
                                "dpWidthValue :: $dpWidthValue"
                            ))
                            // ===============================================================
                            val width = TypedValue.applyDimension(
                                TypedValue.COMPLEX_UNIT_DIP,
                                dpWidthValue.toFloat(),
                                mContext.resources.displayMetrics
                            ).toInt()
                            val height = width + width / 3
                            lp.width = width
                            lp.height = height
                            window.attributes = lp
                            // */
                        }
                    }, 0)
                } catch (e: Exception) {
                    e.printStackTrace()

                    // ------------------------------------------------------
                    // TODO [리턴 데이터 반환]
                    // ------------------------------------------------------
                    try {
                        subscriber.onNext("")
                        subscriber.onComplete()
                    } catch (ex: Exception) {
                        ex.printStackTrace()
                    }
                }
            }
        }

 

반응형
Comments