সিস্টেম বার সুরক্ষা সম্পর্কে

একবার আপনার অ্যাপটি SDK 35 বা তার পরবর্তী সংস্করণকে টার্গেট করলে, edge-to-edge প্রয়োগ করা হয় । সিস্টেম স্ট্যাটাস বার এবং জেসচার নেভিগেশন বারগুলি স্বচ্ছ থাকে, কিন্তু তিন-বোতামের নেভিগেশন বারটি স্বচ্ছ থাকে। এটিকে পিছনের দিকে সামঞ্জস্যপূর্ণ করতে enableEdgeToEdge কল করুন।

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

স্বচ্ছ সিস্টেম বার তৈরি করুন

Android 15 বা তার পরবর্তী ভার্সনগুলিকে টার্গেট করে অথবা পূর্ববর্তী ভার্সনের জন্য ডিফল্ট আর্গুমেন্ট সহ enableEdgeToEdge() কল করে একটি স্বচ্ছ জেসচার নেভিগেশন বার তৈরি করুন। তিন-বোতামের নেভিগেশন বারের জন্য, Window.setNavigationBarContrastEnforced কে false তে সেট করুন অন্যথায় একটি স্বচ্ছ স্ক্রিম প্রয়োগ করা হবে।

স্বচ্ছ সিস্টেম বার তৈরি করুন

একটি স্বচ্ছ স্ট্যাটাস বার তৈরি করতে, একটি কাস্টম কম্পোজেবল তৈরি করুন যা মূল বিষয়বস্তুকে ওভারল্যাপ করে এবং ইনসেট দ্বারা আচ্ছাদিত এলাকায় একটি গ্রেডিয়েন্ট আঁকে।

class SystemBarProtectionSnippets : ComponentActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        // enableEdgeToEdge sets window.isNavigationBarContrastEnforced = true
        // which is used to add a translucent scrim to three-button navigation
        enableEdgeToEdge()

        setContent {
            MyTheme {
                // Main content
                MyContent()

                // After drawing main content, draw status bar protection
                StatusBarProtection()
            }
        }
    }
}

@Composable
private fun StatusBarProtection(
    color: Color = MaterialTheme.colorScheme.surfaceContainer,
    heightProvider: () -> Float = calculateGradientHeight(),
) {

    Canvas(Modifier.fillMaxSize()) {
        val calculatedHeight = heightProvider()
        val gradient = Brush.verticalGradient(
            colors = listOf(
                color.copy(alpha = 1f),
                color.copy(alpha = .8f),
                Color.Transparent
            ),
            startY = 0f,
            endY = calculatedHeight
        )
        drawRect(
            brush = gradient,
            size = Size(size.width, calculatedHeight),
        )
    }
}

@Composable
fun calculateGradientHeight(): () -> Float {
    val statusBars = WindowInsets.statusBars
    val density = LocalDensity.current
    return { statusBars.getTop(density).times(1.2f) }
}

চিত্র ১. একটি স্বচ্ছ স্ট্যাটাস বার।

অ্যাডাপ্টিভ অ্যাপের জন্য, প্রতিটি পেনের রঙের সাথে মেলে এমন একটি কাস্টম কম্পোজেবল সন্নিবেশ করান, যেমনটি Edge-to-edge ডিজাইনে দেখা যায়। একটি স্বচ্ছ নেভিগেশন বার তৈরি করতে, Window.setNavigationBarContrastEnforced true তে সেট করুন।