GlanceAppWidget পরিচালনা এবং আপডেট করুন

নিম্নলিখিত বিভাগগুলি বর্ণনা করে কিভাবে GlanceAppWidget আপডেট করতে হয় এবং এর অবস্থা পরিচালনা করতে হয়।

GlanceAppWidget অবস্থা পরিচালনা করুন

প্রদত্ত GlanceAppWidget ক্লাসটি যখনই উইজেট তৈরি করা হয় বা একটি আপডেটের প্রয়োজন হয় তখনই তাৎক্ষণিক হয়, তাই এটি রাষ্ট্রহীন এবং নিষ্ক্রিয় হওয়া উচিত।

রাষ্ট্রের ধারণাকে নিম্নলিখিত ভাগে ভাগ করা যায়:

  • অ্যাপ্লিকেশানের অবস্থা : উইজেটের জন্য প্রয়োজনীয় অ্যাপের অবস্থা বা বিষয়বস্তু। উদাহরণস্বরূপ, সংরক্ষিত গন্তব্যের একটি তালিকা (অর্থাৎ, ডাটাবেস) ব্যবহারকারী দ্বারা সংজ্ঞায়িত।
  • এক নজরে অবস্থা : নির্দিষ্ট অবস্থা যেটি শুধুমাত্র অ্যাপ উইজেটের সাথে প্রাসঙ্গিক এবং অ্যাপের অবস্থাকে পরিবর্তন বা প্রভাবিত করে না। উদাহরণস্বরূপ, উইজেটে একটি চেকবক্স নির্বাচন করা হয়েছে বা একটি কাউন্টার বাড়ানো হয়েছে৷

অ্যাপ্লিকেশন অবস্থা ব্যবহার করুন

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

উদাহরণস্বরূপ, নিম্নলিখিত কোডটি রিপোজিটরি স্তর থেকে ইন-মেমরি ক্যাশে থেকে গন্তব্যগুলি পুনরুদ্ধার করে, গন্তব্যগুলির সংরক্ষিত তালিকা প্রদান করে এবং এর অবস্থার উপর নির্ভর করে একটি ভিন্ন UI প্রদর্শন করে:

class DestinationAppWidget : GlanceAppWidget() {

    // ...

    @Composable
    fun MyContent() {
        val repository = remember { DestinationsRepository.getInstance() }
        // Retrieve the cache data everytime the content is refreshed
        val destinations by repository.destinations.collectAsState(State.Loading)

        when (destinations) {
            is State.Loading -> {
                // show loading content
            }

            is State.Error -> {
                // show widget error content
            }

            is State.Completed -> {
                // show the list of destinations
            }
        }
    }
}

যখনই রাজ্য বা ডেটা পরিবর্তন হয়, উইজেটটি অবহিত করা এবং আপডেট করার দায়িত্ব অ্যাপের। আরও তথ্যের জন্য GlanceAppWidget আপডেট দেখুন।

GlanceAppWidget আপডেট করুন

GlanceAppWidget ম্যানেজ স্টেট বিভাগে যেমন ব্যাখ্যা করা হয়েছে, অ্যাপ উইজেটগুলি একটি ভিন্ন প্রক্রিয়ায় হোস্ট করা হয়। Glance বিষয়বস্তুকে প্রকৃত RemoteViews এ অনুবাদ করে এবং হোস্টে পাঠায়। বিষয়বস্তু আপডেট করতে, Glance অবশ্যই RemoteViews পুনরায় তৈরি করতে হবে এবং সেগুলি আবার পাঠাতে হবে।

আপডেট পাঠাতে, GlanceAppWidget ইন্সট্যান্সের update পদ্ধতিতে কল করুন, context এবং glanceId প্রদান করুন:

MyAppWidget().update(context, glanceId)

glanceId পেতে, GlanceAppWidgetManager কে জিজ্ঞাসা করুন:

val manager = GlanceAppWidgetManager(context)
val widget = GlanceSizeModeWidget()
val glanceIds = manager.getGlanceIds(widget.javaClass)
glanceIds.forEach { glanceId ->
    widget.update(context, glanceId)
}

বিকল্পভাবে, GlanceAppWidget update এক্সটেনশনগুলির একটি ব্যবহার করুন:

// Updates all placed instances of MyAppWidget
MyAppWidget().updateAll(context)

// Iterate over all placed instances of MyAppWidget and update if the state of
// the instance matches the given predicate
MyAppWidget().updateIf<State>(context) { state ->
    state == State.Completed
}

এই পদ্ধতিগুলি আপনার অ্যাপ্লিকেশনের যেকোনো অংশ থেকে কল করা যেতে পারে। যেহেতু সেগুলি suspend ফাংশন, আমরা সেগুলিকে মূল থ্রেডের সুযোগের বাইরে চালু করার পরামর্শ দিই৷ নিম্নলিখিত উদাহরণে, তারা একটি CoroutineWorker মধ্যে চালু করা হয়েছে:

class DataSyncWorker(
    val context: Context,
    val params: WorkerParameters,
) : CoroutineWorker(context, params) {

    override suspend fun doWork(): Result {
        // Fetch data or do some work and then update all instance of your widget
        MyAppWidget().updateAll(context)
        return Result.success()
    }
}

কোরটিন সম্পর্কে আরও বিশদ বিবরণের জন্য অ্যান্ড্রয়েডে কোটলিন কোরটিনস দেখুন।