উদাহরণ সহ RxJava এবং Android Integration

Java Technologies - আরএক্সজাভা (RxJava) - RxJava এবং Android Integration
190

RxJava কে Android অ্যাপ্লিকেশনে ইন্টিগ্রেট (Integrate) করার মাধ্যমে অ্যাসিঙ্ক্রোনাস এবং ইভেন্ট-ড্রিভেন প্রোগ্রামিং আরও সহজ ও কার্যকরী করা যায়। Android এর UI থ্রেডে কোনো ধরনের ব্লকিং অপারেশন না করার জন্য RxJava ব্যবহার করা হয়ে থাকে। RxJava ব্যবহার করে, ব্যাকগ্রাউন্ড থ্রেডে কাজ করে UI থ্রেডে ফলাফল পাঠানো হয়, যা অ্যাপ্লিকেশনকে দ্রুত ও রেসপন্সিভ রাখে।


Android-এ RxJava ব্যবহারের প্রয়োজনীয়তা

অ্যাসিঙ্ক্রোনাস কার্যাবলী

Android অ্যাপে ব্যাকগ্রাউন্ডে বিভিন্ন কাজ যেমন ডেটা ফেচিং, API কল, বা সেভিং-এর জন্য অ্যাসিঙ্ক্রোনাস কোড ব্যবহৃত হয়। RxJava এই কাজগুলোকে খুব সহজ ও পরিষ্কারভাবে ম্যানেজ করতে সহায়তা করে।

UI থ্রেডে কোনো ব্লকিং অপারেশন না করা

RxJava অ্যাসিঙ্ক্রোনাস অপারেশন পরিচালনা করতে সক্ষম হওয়ায়, UI থ্রেডে কোনো ব্লকিং অপারেশন করতে হয় না, যা অ্যাপ্লিকেশনকে স্নিগ্ধ এবং রেসপন্সিভ রাখে।


RxJava এবং Android Integration উদাহরণ

১. API Call এবং Response Handling

এখানে আমরা দেখব কিভাবে RxJava ব্যবহার করে একটি API কল করা হয় এবং তার ফলাফল UI তে দেখানো হয়।

Step 1: Retrofit এবং RxJava যুক্ত করা

প্রথমে, আমাদের build.gradle ফাইলে Retrofit এবং RxJava এর dependency যোগ করতে হবে।

dependencies {
    implementation 'com.squareup.retrofit2:retrofit:2.9.0'
    implementation 'com.squareup.retrofit2:converter-gson:2.9.0'
    implementation 'io.reactivex.rxjava2:rxjava:2.2.21'
    implementation 'io.reactivex.rxjava2:rxandroid:2.1.1'
}

Step 2: API Interface তৈরি করা

public interface ApiService {
    @GET("users/{user}/repos")
    Observable<List<Repo>> getRepos(@Path("user") String user);
}

Step 3: Retrofit সেটআপ করা

Retrofit retrofit = new Retrofit.Builder()
    .baseUrl("https://api.github.com/")
    .addConverterFactory(GsonConverterFactory.create())
    .build();

ApiService apiService = retrofit.create(ApiService.class);

Step 4: RxJava এর মাধ্যমে API Call করা এবং UI তে ফলাফল দেখানো

public class MainActivity extends AppCompatActivity {

    private TextView textView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        textView = findViewById(R.id.textView);

        apiService.getRepos("octocat")
            .subscribeOn(Schedulers.io())   // API call will happen on background thread
            .observeOn(AndroidSchedulers.mainThread())  // Result will be observed on main thread
            .subscribe(new Observer<List<Repo>>() {
                @Override
                public void onSubscribe(Disposable d) {}

                @Override
                public void onNext(List<Repo> repos) {
                    // Update UI with the response
                    textView.setText(repos.size() + " Repos found.");
                }

                @Override
                public void onError(Throwable e) {
                    // Handle error
                    textView.setText("Error: " + e.getMessage());
                }

                @Override
                public void onComplete() {}
            });
    }
}

এখানে, getRepos API কলটি Observable রিটার্ন করে, যা RxJava এর মাধ্যমে অ্যাসিঙ্ক্রোনাসভাবে সম্পন্ন হয়। subscribeOn(Schedulers.io()) ব্যাকগ্রাউন্ড থ্রেডে API কলটি সম্পন্ন করবে এবং observeOn(AndroidSchedulers.mainThread()) মূল UI থ্রেডে ফলাফল দেখাবে।


RxJava দিয়ে UI ইভেন্ট হ্যান্ডলিং

২. Button Click ইভেন্ট হ্যান্ডলিং

এখানে আমরা দেখব কিভাবে একটি Button এর ক্লিক ইভেন্ট RxJava দিয়ে হ্যান্ডল করা যায়।

Button button = findViewById(R.id.button);

Observable.create(new ObservableOnSubscribe<Void>() {
    @Override
    public void subscribe(ObservableEmitter<Void> emitter) throws Exception {
        button.setOnClickListener(v -> emitter.onNext(null));
    }
})
.subscribeOn(AndroidSchedulers.mainThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Observer<Void>() {
    @Override
    public void onSubscribe(Disposable d) {}

    @Override
    public void onNext(Void aVoid) {
        // Handle button click here
        Toast.makeText(MainActivity.this, "Button Clicked!", Toast.LENGTH_SHORT).show();
    }

    @Override
    public void onError(Throwable e) {}

    @Override
    public void onComplete() {}
});

এখানে, Observable.create() ব্যবহার করে একটি কাস্টম Observable তৈরি করা হয়েছে যা Button ক্লিকের উপর ভিত্তি করে কাজ করে। ক্লিক করার পর এটি UI থ্রেডে Toast মেসেজ প্রদর্শন করবে।


উপসংহার

RxJava Android অ্যাপে অ্যাসিঙ্ক্রোনাস কার্যাবলী এবং ইভেন্ট-ড্রিভেন প্রোগ্রামিং সহজ করে তোলে। Retrofit এর সঙ্গে একত্রে ব্যবহার করে, এটি অ্যাপ্লিকেশনগুলোকে আরও কার্যকরী এবং রেসপন্সিভ করে তোলে। এছাড়াও, RxJava ব্যবহার করে UI ইভেন্ট হ্যান্ডলিং আরও পরিষ্কার এবং ম্যানেজেবল হয়, যা অ্যাপ্লিকেশন উন্নয়নকে দ্রুত এবং সহজ করে তোলে।


Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...