투케이2K

869. (Android/Java) [유틸 파일] observableNdefWriteNfc : NFC 카드 NDEF 메시지 쓰기 - onNewIntent Nfc NDEF Write 본문

Android

869. (Android/Java) [유틸 파일] observableNdefWriteNfc : NFC 카드 NDEF 메시지 쓰기 - onNewIntent Nfc NDEF Write

투케이2K 2024. 9. 6. 13:08
반응형

[개발 환경 설정]

개발 툴 : AndroidStudio

개발 언어 : Java / Kotlin

 

[소스 코드]

 

    // -----------------------------------------------------------------------------------------
    // TODO [Observable] : [NDEF 카드 데이터 쓰기]
    // -----------------------------------------------------------------------------------------
    // TODO [호출 방법 소스 코드]
    // -----------------------------------------------------------------------------------------
    /*
    try {
        Tag tag = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG);
        String message = "hello twok";

        c_nfc_card_module.observableNdefWriteNfc(tag, message)
                .subscribeOn(AndroidSchedulers.mainThread()) // [Observable (생성자) 로직을 IO 스레드에서 실행 : 백그라운드]
                .observeOn(Schedulers.io()) // [Observer (관찰자) 로직을 메인 스레드에서 실행]
                .subscribe(new Observer<Boolean>() { // [Observable.create 타입 지정]
                    @Override
                    public void onSubscribe(@NonNull Disposable d) {
                    }
                    @Override
                    public void onNext(@NonNull Boolean value) {
                        S_Log._W_("observableReadNfc :: NFC NDEF 메시지 쓰기 확인 수행", new String[]{String.valueOf(value)});
                    }
                    @Override
                    public void onError(@NonNull Throwable e) {
                        S_Log._E_("observableReadNfc :: NFC NDEF 메시지 쓰기 에러", new String[]{String.valueOf(e.getMessage())});
                    }
                    @Override
                    public void onComplete() {
                    }
                });
    }
    catch (Exception e){
        S_Log._printStackTrace_(null, S_FinalData.LOG_BUG_STATE, null, e);
    }
    */
    // -----------------------------------------------------------------------------------------
    public Observable<Boolean> observableNdefWriteNfc(Tag tag, String message){


        /*
        D  ===================================================================
        [LOG :: CLASS PLACE :: com.example.javaproject.C_Module.C_Nfc_Card_Module.lambda$observableNdefWriteNfc$1$com-example-javaproject-C_Module-C_Nfc_Card_Module(C_Nfc_Card_Module.java:572)]
        ----------------------------------------------------
        [LOG :: NOW TIME :: 2024-09-06 11:29:15 금요일]
        ----------------------------------------------------
        [LOG :: DESCRIPTION :: C_Nfc_Card_Module :: NFC 카드 NDEF 메시지 쓰기 수행]
        ----------------------------------------------------
        [LOG :: hello twok]
        D  ===================================================================
        */


        // [로직 처리 실시]
        return Observable.create(subscriber -> {

            try {
                // ===============================================================
                S_Log._D_(ACTIVITY_NAME + " :: NFC 카드 NDEF 메시지 쓰기 수행", new String[]{String.valueOf(message)});
                // ===============================================================

                // [팝업창 생성 실시]
                new Handler(Looper.getMainLooper()).postDelayed(new Runnable() {
                    @Override
                    public void run() {

                        if (mMainCtx != null && nfcAdapter != null){

                            if (tag != null){

                                // -------------------------------------------------
                                // TODO [NFC NDEF 메시지 쓰기]
                                // -------------------------------------------------
                                try {

                                    Ndef ndef = Ndef.get(tag);

                                    if (ndef != null){

                                        NdefRecord mRecord = NdefRecord.createTextRecord("en",String.valueOf(message)); // [레코드 생성]

                                        NdefMessage mMsg = new NdefMessage(mRecord); // [메시지 생성]

                                        ndef.connect(); // [연결]

                                        ndef.writeNdefMessage(mMsg); // [쓰기]

                                        ndef.close(); // [종료]

                                        if (subscriber != null && subscriber.isDisposed() == false){ // TODO [리턴 반환]
                                            subscriber.onNext(true);
                                            subscriber.onComplete();
                                        }

                                    }
                                    else {

                                        // TODO [리턴 데이터 반환]
                                        try {
                                            if (subscriber != null && subscriber.isDisposed() == false){
                                                subscriber.onError(new Throwable("[Error] : Ndef Is Null"));
                                                subscriber.onComplete();
                                            }
                                        }
                                        catch (Exception ex){
                                            ex.printStackTrace();
                                        }

                                    }

                                }
                                catch (Exception es){
                                    es.printStackTrace();

                                    // TODO [리턴 데이터 반환]
                                    try {
                                        if (subscriber != null && subscriber.isDisposed() == false){
                                            subscriber.onError(new Throwable("[Exception] : " + String.valueOf(es.getMessage())));
                                            subscriber.onComplete();
                                        }
                                    }
                                    catch (Exception ex){
                                        ex.printStackTrace();
                                    }
                                }

                            }
                            else {

                                // TODO [리턴 데이터 반환]
                                try {
                                    if (subscriber != null && subscriber.isDisposed() == false){
                                        subscriber.onError(new Throwable("[Error] : Tag Is Null"));
                                        subscriber.onComplete();
                                    }
                                }
                                catch (Exception ex){
                                    ex.printStackTrace();
                                }

                            }

                        }
                        else {
                            // TODO [리턴 데이터 반환]
                            try {
                                if (subscriber != null && subscriber.isDisposed() == false){
                                    subscriber.onError(new Throwable("[Error] : Context , nfcAdapter Is Null"));
                                    subscriber.onComplete();
                                }
                            }
                            catch (Exception ex){
                                ex.printStackTrace();
                            }
                        }

                    }
                }, 0);

            } catch (final Exception e){
                S_Log._printStackTrace_(null, S_FinalData.LOG_BUG_STATE, null, e);

                // TODO [리턴 데이터 반환]
                try {
                    if (subscriber != null && subscriber.isDisposed() == false){
                        subscriber.onError(new Throwable("[Exception] : " + String.valueOf(e.getMessage())));
                        subscriber.onComplete();
                    }
                }
                catch (Exception ex){
                    ex.printStackTrace();
                }
            }

        });
    }

 

반응형
Comments