Jetpack XR SDK टूल की मदद से, 3D मॉडल, स्टीरियोस्कोपिक वीडियो, और PanelEntity
जैसे Entity
इंस्टेंस बनाने, उन्हें कंट्रोल करने, और मैनेज करने के लिए, Jetpack SceneCore का इस्तेमाल किया जा सकता है.
Jetpack SceneCore, 3D डेवलपमेंट के लिए आर्किटेक्चर के दो सामान्य पैटर्न अपनाता है: सीन ग्राफ़ और इकाई-कॉम्पोनेंट सिस्टम (ईसीएस).
इकाइयां बनाने और उन्हें कंट्रोल करने के लिए, सीन ग्राफ़ का इस्तेमाल करना
3D स्पेस में ऑब्जेक्ट बनाने और उन्हें कंट्रोल करने के लिए, सीन ग्राफ़ का ऐक्सेस पाने के लिए, Jetpack SceneCore के Session API का इस्तेमाल किया जा सकता है. सीन ग्राफ़, उपयोगकर्ता की असल दुनिया के साथ अलाइन होता है. साथ ही, पैनल और 3D मॉडल जैसी 3D इकाइयों को हैरारकी वाले स्ट्रक्चर में व्यवस्थित करने और उन इकाइयों की स्थिति को बनाए रखने में मदद करता है.
सीन ग्राफ़ का ऐक्सेस मिलने के बाद, XR के लिए Jetpack Compose में मौजूद एपीआई का इस्तेमाल करके, सीन ग्राफ़ में स्पेसिएल यूज़र इंटरफ़ेस (उदाहरण के लिए, SpatialPanel
और
Orbiter
इंस्टेंस) बनाया जा सकता है. 3D मॉडल जैसे 3D कॉन्टेंट के लिए, सीधे सेशन को ऐक्सेस किया जा सकता है. ज़्यादा जानने के लिए, इस पेज पर ActivitySpace के बारे में जानकारी देखें.
इकाई का कॉम्पोनेंट सिस्टम
इकाई-कॉम्पोनेंट सिस्टम, इनहेरिटेंस के बजाय कंपोज़िशन के सिद्धांत का पालन करता है. इकाइयों के व्यवहार को बेहतर बनाने के लिए, व्यवहार तय करने वाले कॉम्पोनेंट जोड़े जा सकते हैं. इससे, अलग-अलग तरह की इकाइयों पर एक जैसा व्यवहार लागू किया जा सकता है. ज़्यादा जानकारी के लिए, इस पेज पर इकाइयों के लिए सामान्य व्यवहार जोड़ना लेख पढ़ें.
ActivitySpace के बारे में जानकारी
हर Session
में एक ActivitySpace
होता है, जो Session
के साथ अपने-आप बन जाता है. ActivitySpace
, सीन ग्राफ़ में टॉप लेवल का Entity
है.
ActivitySpace, तीन डाइमेंशन वाले स्पेस को दिखाता है. इसमें राइट-हैंडड कोऑर्डिनेट सिस्टम (x-ऐक्सिस दाईं ओर, y-ऐक्सिस ऊपर, और z-ऐक्सिस ऑरिजिन के पीछे) होता है. साथ ही, इसमें इकाइयों के लिए मीटर का इस्तेमाल किया जाता है, जो असल दुनिया से मेल खाते हैं. ActivitySpace
का ऑरिजिन कुछ हद तक मनमुताबिक होता है, क्योंकि उपयोगकर्ता असल दुनिया में ActivitySpace
की पोज़िशन को रीसेट कर सकते हैं. इसलिए, हमारा सुझाव है कि कॉन्टेंट को ऑरिजिन के बजाय, एक-दूसरे के हिसाब से पोज़िशन करें.
इकाइयों के साथ काम करना
इकाइयां, SceneCore के लिए अहम हैं. उपयोगकर्ता को जो भी दिखता है और जिनसे वह इंटरैक्ट करता है वे इकाइयां, पैनल, 3D मॉडल वगैरह होती हैं.
ActivitySpace
, सीन ग्राफ़ का टॉप-लेवल नोड है. इसलिए, डिफ़ॉल्ट रूप से, सभी नई इकाइयों को सीधे ActivitySpace
में रखा जाता है. setParent()
या
addChild()
को कॉल करके, सीन ग्राफ़ में इकाइयों को फिर से सेट किया जा सकता है.
इकाइयों के लिए कुछ डिफ़ॉल्ट व्यवहार होते हैं. ये सभी इकाइयों के लिए यूनिवर्सल होते हैं. जैसे, पोज़िशन, रोटेशन या दिखने की स्थिति बदलना. GltfEntity
जैसी खास Entity
सबक्लास में, सबक्लास के साथ काम करने वाले अतिरिक्त व्यवहार होते हैं.
इकाइयों में बदलाव करना
जब किसी Entity
प्रॉपर्टी में बदलाव किया जाता है, जो बेस Entity
क्लास से जुड़ी होती है, तो यह बदलाव उसके सभी चाइल्ड पर लागू हो जाएगा. उदाहरण के लिए, किसी पैरंट Entity
के Pose
में बदलाव करने पर, उसके सभी चाइल्ड में भी वही बदलाव होता है. चाइल्ड Entity
में बदलाव करने से, पैरंट पर कोई असर नहीं पड़ता.
Pose
, 3D स्पेस में इकाई की जगह और घुमाव को दिखाता है. जगह एक Vector3
है, जिसमें x, y, z संख्यात्मक पोज़िशन शामिल हैं. रोटेशन को Quaternion
से दिखाया जाता है. Entity
की स्थिति हमेशा अपनी पैरंट इकाई के हिसाब से होती है. दूसरे शब्दों में, जिस Entity
की पोज़िशन (0, 0, 0) है उसे पैरंट इकाई के ऑरिजिन पर रखा जाएगा.
// Place the entity forward 2 meters val newPosition = Vector3(0f, 0f, -2f) // Rotate the entity by 180 degrees on the up axis (upside-down) val newOrientation = Quaternion.fromEulerAngles(0f, 0f, 180f) // Update the position and rotation on the entity entity.setPose(Pose(newPosition, newOrientation))
किसी Entity
की 'किसको दिखे' सेटिंग बदलने के लिए, setHidden()
का इस्तेमाल करें.
// Hide the entity entity.setHidden(true)
Entity
का साइज़ बदलने के लिए, setScale()
का इस्तेमाल करें.
// Double the size of the entity entity.setScale(2f)
इकाइयों के लिए सामान्य व्यवहार जोड़ना
इकाइयों में सामान्य व्यवहार जोड़ने के लिए, इन कॉम्पोनेंट का इस्तेमाल किया जा सकता है:
MovableComponent
: उपयोगकर्ता को इकाइयों को एक से दूसरी जगह ले जाने की अनुमति देता हैResizableComponent
: यह विकल्प, उपयोगकर्ता को यूज़र इंटरफ़ेस (यूआई) के एक जैसे पैटर्न का इस्तेमाल करके, इकाइयों का साइज़ बदलने की अनुमति देता हैInteractableComponent
: इसकी मदद से, कस्टम इंटरैक्शन के लिए इनपुट इवेंट कैप्चर किए जा सकते हैं
कॉम्पोनेंट को इंस्टैंशिएट करने के लिए, Session
क्लास में कॉम्पोनेंट बनाने का सही तरीका अपनाना ज़रूरी है. उदाहरण के लिए, ResizableComponent
बनाने के लिए, ResizableComponent.create()
को कॉल करें.
Entity
में किसी कॉम्पोनेंट के खास व्यवहार को जोड़ने के लिए,
addComponent()
का इस्तेमाल करें.
इकाई को उपयोगकर्ता के लिए मूव करने लायक बनाने के लिए, MovableComponent का इस्तेमाल करना
MovableComponent
की मदद से, उपयोगकर्ता Entity
को एक जगह से दूसरी जगह ले जा सकता है. यह भी तय किया जा सकता है कि इकाई को किसी तरह की सतह पर ऐंकर किया जा सकता है या नहीं. जैसे, हॉरिज़ॉन्टल या वर्टिकल सतहें या टेबल, दीवार या छत जैसी खास सिमेंटिक सतहें. ऐंकर के विकल्पों की जानकारी देने के लिए, MovableComponent
बनाते समय AnchorPlacement
का एक सेट तय करें.
यहां एक ऐसी इकाई का उदाहरण दिया गया है जिसे किसी भी वर्टिकल प्लैटफ़ॉर्म पर ले जाया और ऐंकर किया जा सकता है. साथ ही, इसे सिर्फ़ फ़्लोर और सीलिंग के हॉरिज़ॉन्टल प्लैटफ़ॉर्म पर ले जाया जा सकता है.
val anchorPlacement = AnchorPlacement.createForPlanes( planeTypeFilter = setOf(PlaneSemantic.FLOOR, PlaneSemantic.TABLE), planeSemanticFilter = setOf(PlaneType.VERTICAL) ) val movableComponent = MovableComponent.create( session = session, systemMovable = false, scaleInZ = false, anchorPlacement = setOf(anchorPlacement) ) entity.addComponent(movableComponent)
जब उपयोगकर्ता इकाई को एक जगह से दूसरी जगह ले जाता है, तो scaleInZ
पैरामीटर अपने-आप इकाई के स्केल में बदलाव करता है. यह उसी तरह होता है जिस तरह होम स्पेस में सिस्टम, पैनल का स्केल बदलता है. इकाई कॉम्पोनेंट सिस्टम की "कैस्केडिंग" गतिविधि की वजह से, पैरंट के स्केल का असर उसके सभी चाइल्ड पर पड़ेगा.
ResizableComponent का इस्तेमाल करके, इकाई को उपयोगकर्ता के हिसाब से बड़ा या छोटा किया जा सकता है
ResizableComponent
की मदद से, उपयोगकर्ता Entity
का साइज़ बदल सकते हैं. ResizableComponent
में विज़ुअल इंटरैक्शन के ऐसे संकेत शामिल होते हैं जिनसे उपयोगकर्ता को Entity
का साइज़ बदलने का न्योता मिलता है. ResizeableComponent
बनाते समय, कम से कम या ज़्यादा से ज़्यादा साइज़ (मीटर में) तय किया जा सकता है. साइज़ बदलते समय, आपके पास आसपेक्ट रेशियो (लंबाई-चौड़ाई का अनुपात) तय करने का विकल्प भी होता है. इससे चौड़ाई और ऊंचाई, एक-दूसरे के हिसाब से बदल जाती है.
ResieableComponent
का इस्तेमाल करते समय, आपको onResizeUpdate
या
onResizeEnd
जैसे साइज़ बदलने वाले खास इवेंट का जवाब देने के लिए, ResizeListener
की जानकारी देनी होगी.
यहां SurfaceEntity
पर, तय आसपेक्ट रेशियो के साथ ResizableComponent
का इस्तेमाल करने का उदाहरण दिया गया है:
val resizableComponent = ResizableComponent.create(session) resizableComponent.minimumSize = Dimensions(177f, 100f, 1f) resizableComponent.fixedAspectRatio = 16f / 9f // Specify a 16:9 aspect ratio resizableComponent.addResizeListener( executor, object : ResizeListener { override fun onResizeEnd(entity: Entity, finalSize: Dimensions) { // update the size in the component resizableComponent.size = finalSize // update the Entity to reflect the new size (entity as SurfaceEntity).canvasShape = SurfaceEntity.CanvasShape.Quad(finalSize.width, finalSize.height) } }, ) entity.addComponent(resizableComponent)
उपयोगकर्ता के इनपुट इवेंट कैप्चर करने के लिए, InteractableComponent का इस्तेमाल करना
InteractableComponent
की मदद से, उपयोगकर्ता से इनपुट इवेंट कैप्चर किए जा सकते हैं. जैसे, जब उपयोगकर्ता किसी Entity
पर क्लिक करता है या उस पर कर्सर घुमाता है. InteractableComponent
बनाते समय, आपको इनपुट इवेंट पाने के लिए InputEventListener
तय करना होगा. जब उपयोगकर्ता कोई इनपुट ऐक्शन करता है, तो InputEvent
पैरामीटर में दी गई खास इनपुट जानकारी के साथ onInputEvent
मेथड को कॉल किया जाएगा.
InputEvent.action
से, इनपुट का टाइप पता चलता है. जैसे, किसी इकाई पर हॉवर करना या टैप करनाInputEvent.source
से पता चलता है कि इनपुट कहां से आया है, जैसे कि हाथ या कंट्रोलर इनपुटInputEvent.pointerType
से पता चलता है कि इनपुट, दाएं हाथ से आया है या बाएं हाथ से
सभी InputEvent
कॉन्स्टेंट की पूरी सूची के लिए, रेफ़रंस दस्तावेज़ देखें.
नीचे दिया गया कोड स्निपेट, InteractableComponent
का इस्तेमाल करके किसी इकाई के साइज़ को बढ़ाने और घटाने का उदाहरण दिखाता है. इसके लिए, दाएं हाथ का इस्तेमाल किया जाता है और बाएं हाथ का इस्तेमाल किया जाता है.
val executor = Executors.newSingleThreadExecutor() val interactableComponent = InteractableComponent.create(session, executor) { // when the user disengages with the entity with their hands if (it.source == InputEvent.SOURCE_HANDS && it.action == InputEvent.ACTION_UP) { // increase size with right hand and decrease with left if (it.pointerType == InputEvent.POINTER_TYPE_RIGHT) { entity.setScale(1.5f) } else if (it.pointerType == InputEvent.POINTER_TYPE_LEFT) { entity.setScale(0.5f) } } } entity.addComponent(interactableComponent)