Notice
Recent Posts
Recent Comments
Link
투케이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();
}
}
});
}
반응형
'Android' 카테고리의 다른 글
Comments