অ্যান্ড্রয়েড ভিউ-ভিত্তিক অ্যাপের জন্য UI ডেভেলপ করুন

রচনা পদ্ধতি চেষ্টা করুন
Jetpack XR SDK ব্যবহার করে জেটপ্যাক কম্পোজ করা হল Android XR-এর জন্য প্রস্তাবিত UI টুলকিট।

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

যাইহোক, আপনি যদি স্থানান্তরিত না হয়ে থাকেন এবং একটি অ্যান্ড্রয়েড ভিউ ভিত্তিক অ্যাপকে স্থানান্তরিত করার জন্য কাজ করছেন, তবে আপনি কিছু পন্থা অবলম্বন করতে পারেন।

SpatialPanels-এর মধ্যে আপনার বিদ্যমান ভিউ পুনরায় ব্যবহার করুন

যদিও SpatialPanel XR লাইব্রেরির জন্য Jetpack Compose-এর অংশ, তারা ভিউও গ্রহণ করে। আপনার MainActivity-এ setSubspaceContent ব্যবহার করার সময়, নিম্নলিখিত উদাহরণে দেখানো হিসাবে একটি SpatialPanel এ একটি বিদ্যমান ভিউ রাখুন।

setSubspaceContent {
    SpatialPanel(
        modifier = SubspaceModifier.height(500.dp).width(500.dp).depth(25.dp)
    ) { MyCustomView(this) }
}

অ্যান্ড্রয়েড ভিউ এবং কম্পোজ ইন্টারঅপারেবিলিটি API ব্যবহার করুন

ভিউ এবং কম্পোজের মধ্যে ইন্টারঅপারেবিলিটি সম্পর্কে নির্দেশিকা দেখুন। এই ডকুমেন্টেশনটি এই ফ্রেমওয়ার্কগুলিকে একসাথে ব্যবহার করে কভার করে এবং আপনি ব্যবহার করতে পারেন এমন কোড নমুনার লিঙ্ক রয়েছে৷

একটি বিদ্যমান খণ্ডে স্থানিক প্যানেল এবং অরবিটার যোগ করতে একটি ComposeView ব্যবহার করুন

Composables যোগ করতে এবং নতুন XR সামগ্রী তৈরি করতে আপনার XML লেআউটে একটি ComposeView ব্যবহার করুন। onCreateView ফাংশনে ComposeView খুঁজতে ভিউ বাইন্ডিং বা findViewById ব্যবহার করুন।

ComposeView নির্দেশিকা সম্পর্কে আরও পড়ুন

override fun onCreateView(
    inflater: LayoutInflater,
    container: ViewGroup?,
    savedInstanceState: Bundle?
): View {
    val view = inflater.inflate(R.layout.example_fragment, container, false)
    view.findViewById<ComposeView>(R.id.compose_view).apply {
        // Dispose of the Composition when the view's LifecycleOwner
        // is destroyed
        setViewCompositionStrategy(ViewCompositionStrategy.DisposeOnViewTreeLifecycleDestroyed)
        setContent {
            // In Compose world
            SpatialPanel(SubspaceModifier.height(500.dp).width(500.dp)) {
                Text("Spatial Panel with Orbiter")
            }
        }
    }
    return view
}

জেটপ্যাক সিনকোর লাইব্রেরির সাথে সরাসরি কাজ করুন

XR-এর জন্য কম্পোজ জেটপ্যাক সিনকোরের উপরে তৈরি করা হয়েছে। আপনি যদি একটি ভিউ ভিত্তিক অ্যাপকে স্থানান্তরিত করে থাকেন, তাহলে আপনি XR-এর জন্য রচনার মধ্যে আপনার বিদ্যমান UI কোড ব্যবহার করা চালিয়ে যেতে পারেন বা এর পরিবর্তে Jetpack SceneCore-এর Session সাথে সরাসরি কাজ করা বেছে নিতে পারেন।

আপনি PanelEntity ব্যবহার করে SceneCore থেকে সরাসরি প্যানেল তৈরি করতে পারেন। Dimensions ব্যবহার করে প্যানেলের সাইজ মিটারে বা PixelDimensions ব্যবহার করে পিক্সেলে সেট করুন। আপনি সংশ্লিষ্ট উপাদানগুলি ব্যবহার করে প্যানেলগুলিকে চলমান বা পরিবর্তনযোগ্য করতে বেছে নিতে পারেন। আরও তথ্যের জন্য, সত্তাগুলিতে সাধারণ আচরণ যুক্ত করুন দেখুন।

val panelContent = MyCustomView(this)
val panelEntity = PanelEntity.create(
    session = xrSession,
    view = panelContent,
    pixelDimensions = PixelDimensions(500, 500),
    name = "panel entity"
)