3D মডেলের সাথে কাজ করার সময়, Jetpack XR SDK glTF 2.0 ওপেন স্ট্যান্ডার্ড সমর্থন করে। যখন Android XR জেটপ্যাক XR SDK-এর সাহায্যে নির্মিত অ্যাপগুলিকে রেন্ডার করে, তখন 3D মডেলগুলিকে glTF 2.0 স্ট্যান্ডার্ডে (সমর্থিত extensions
সহ) নির্দিষ্ট করা শারীরিক ভিত্তিক রেন্ডারিং (PBR) কৌশলগুলির সাথে রেন্ডার করা হবে। অটোডেস্ক মায়া , ম্যাক্সন জেডব্রাশ , ব্লেন্ডার এবং স্প্লাইনের মতো বেশিরভাগ ডিজিটাল সামগ্রী তৈরির (dcc) সরঞ্জামগুলি 3D মডেলগুলি glTF ফর্ম্যাটে ( .gltf
বা .glb
ফাইল) রপ্তানি করতে পারে৷
যদি একটি SpatialEnvironment
স্কাইবক্স ব্যবহারকারীর দ্বারা বা আপনার অ্যাপ দ্বারা নির্দিষ্ট করা হয়, তাহলে পরিবেশ স্কাইবক্স দ্বারা প্রদত্ত আলোক তথ্য দিয়ে 3D মডেলগুলি আলোকিত হবে৷ প্রতিফলিত উপকরণ এবং স্পেকুলার হাইলাইটগুলিও পরিবেশের স্কাইবক্সকে প্রতিফলিত করবে। যদি পাসথ্রু সক্ষম করা থাকে, তাহলে আলো, প্রতিফলন এবং স্পেকুলার হাইলাইটগুলি একটি একক দিকনির্দেশক আলো সহ একটি সাধারণ, উজ্জ্বল কক্ষের উপর ভিত্তি করে হবে৷
সমর্থিত উপকরণগুলির একটি দ্রুত ওভারভিউয়ের জন্য, Khronos সাইটে glTF PBR বৈশিষ্ট্যগুলি পড়ুন৷
3D মডেল লোড করার জন্য Jetpack XR SDK দিয়ে তৈরি অ্যাপের জন্য দুটি প্রাথমিক উপায় রয়েছে।
- নিম্নলিখিত বিভাগে বর্ণিত হিসাবে এটি
ActivitySpace
এ লোড করুন, ActivitySpace-এ একটি 3D মডেল রাখুন - একটি অভিপ্রায় মাধ্যমে অন্তর্নির্মিত দৃশ্য ভিউয়ার ব্যবহার করুন
ActivitySpace এ একটি 3D মডেল রাখুন
একবার আপনার glTF ফাইল হয়ে গেলে, পরবর্তী ধাপ হল এটিকে Android স্টুডিওতে সম্পদ ডিরেক্টরিতে যোগ করা। আপনার সম্পদের প্রকারগুলিকে আরও ভালভাবে সংগঠিত করতে আমরা একটি models
ডিরেক্টরি তৈরি করার পরামর্শ দিই।
glTF মডেল লোড করতে, createGltfResourceAsync
কল করুন।
// load the gltf file
val gltfModel = xrSession.createGltfResourceAsync("models/saturn_rings.glb").await()
এই মুহুর্তে, মডেলটি মেমরিতে লোড করা হয়েছে, তবে এটি এখনও রেন্ডার করা হচ্ছে না। আপনার যদি লোড করার জন্য অনেকগুলি 3D মডেল থাকে বা আপনার মডেল বড় হয়, তবে সময়ের আগে সেগুলিকে অ্যাসিঙ্ক্রোনাসভাবে লোড করা একটি ভাল ধারণা৷ এইভাবে, ব্যবহারকারীদের আপনার মডেলগুলি মেমরিতে লোড হওয়ার জন্য অপেক্ষা করতে হবে না।
আমাদের ActivitySpace
এ glTF যোগ করতে হবে। একটি সত্তা তৈরি করতে createGltfEntity
কল করুন এবং এটি ActivitySpace
এ রাখুন। সর্বোত্তম অনুশীলন হিসাবে, আপনার পরীক্ষা করা উচিত যে অ্যাপটি এমন অবস্থায় রয়েছে যা স্থানিক ক্ষমতার জন্য অনুমতি দেয় ।
// check for spatial capabilities
if (xrSession.getSpatialCapabilities().hasCapability(SpatialCapabilities.SPATIAL_CAPABILITY_3D_CONTENT)){
// create the gltf entity using the gltf file from the previous snippet
val gltfEntity = xrSession.createGltfEntity(gltfModel)
}
আপনি যখন আপনার অ্যাপ চালাবেন তখন আপনার এখন লোড করা 3D মডেলটি দেখতে হবে।
একটি রচনা ভলিউমে একটি 3D মডেল রাখুন
যদিও আপনাকে createGltfResourceAsync
ব্যবহার করে মেমরিতে glTF লোড করতে হবে, আপনি যদি XR-এর জন্য Jetpack Compose দিয়ে আপনার UI তৈরি করেন তাহলে আপনি 3D মডেলকে একটি Volume
রাখতে পারেন। আপনার লেআউটে একটি 3D বস্তু স্থাপন করতে একটি ভলিউম ব্যবহার করুন দেখুন।
অ্যানিমেট 3D মডেল
glTF স্পেসিফিকেশনের অংশ হিসাবে, 3D মডেলগুলিতে অ্যানিমেশন এমবেড করা থাকতে পারে। কঙ্কাল (কাঁটা), অনমনীয়, মর্ফ টার্গেট (মিশ্রিত আকার) অ্যানিমেশনগুলি সমস্ত জেটপ্যাক XR SDK-তে সমর্থিত। KHR_animation_pointer
glTF এক্সটেনশনের সাথে তৈরি করা ম্যাটেরিয়াল অ্যানিমেশনগুলিও সমর্থিত।
একটি অ্যানিমেশন চালাতে, startAnimation
কল করুন এবং অ্যানিমেশনের নাম উল্লেখ করুন। আপনি ঐচ্ছিকভাবে নির্দিষ্ট করতে পারেন যে অ্যানিমেশনটি অনির্দিষ্টকালের জন্য লুপ করা উচিত কিনা।
//start a looping walk animation for a model
gltfEntity.startAnimation(loop = true, animationName = "Walk")
startAnimation
দ্বিতীয়বার কল করলে, বর্তমান অ্যানিমেশন বন্ধ হয়ে যাবে এবং নতুন অ্যানিমেশন শুরু হবে।
আপনি getAnimationState()
মাধ্যমে অ্যানিমেশনের বর্তমান অবস্থা জিজ্ঞাসা করতে পারেন।
startAnimation()
কল করার সময় নির্দিষ্ট করা অ্যানিমেশন নামটি বিদ্যমান না থাকলে, কলটি নিঃশব্দে ব্যর্থ হয়, যেকোনো চলমান অ্যানিমেশন বন্ধ হয়ে যায় এবং getAnimationState()
STOPPED
ফেরত দেয়।
দৃশ্য ভিউয়ার ব্যবহার করে একটি 3D মডেল লোড করুন
আপনি যদি মৌলিক মিথস্ক্রিয়া ক্ষমতা সহ একটি 3D মডেল লোড করার সবচেয়ে সহজ উপায় খুঁজছেন, তাহলে আপনি মোবাইলে যেমন দৃশ্য ভিউয়ার ব্যবহার করতে চান। অ্যান্ড্রয়েড এক্সআর এবং মোবাইলে সিন ভিউয়ারের মধ্যে একটি মূল পার্থক্য হল যে দৃশ্য ভিউয়ার শুধুমাত্র GlTF ফাইলের দিকে নির্দেশ করে URI প্যারামিটারটিকে সমর্থন করে এবং অন্যান্য সমস্ত প্যারামিটার উপেক্ষা করা হয়।
সিন ভিউয়ার হল একটি আলাদা অ্যাপ যা একটি উদ্দেশ্যের মাধ্যমে আহ্বান করা হয় এবং ফুল স্পেস মোডে চলে। ফলস্বরূপ, আপনি যখন এটি চালু করবেন, তখন আপনার অ্যাপটি আর দৃশ্যমান হবে না এবং দৃশ্য দর্শকের ফোকাস থাকবে। আপনি যে পরিবেশ পরিবর্তন করেছেন তা ব্যবহারকারীর সিস্টেম পছন্দগুলিতে পুনরায় সেট করা হবে।
অ্যান্ড্রয়েড এক্সআর-এ দৃশ্য ভিউয়ারে একটি জিএলটিএফ ফাইল দেখার জন্য একটি Intent
ব্যবহার করার একটি উদাহরণ এখানে দেওয়া হল:
val THREED_MODEL_URL = "https://raw.githubusercontent.com/KhronosGroup/glTF-Sample-Models/master/2.0/FlightHelmet/glTF/FlightHelmet.gltf"
val MIME_TYPE = "model/gltf-binary"
val sceneViewerIntent = Intent(Intent.ACTION_VIEW)
val intentUri =
Uri.parse("https://arvr.google.com/scene-viewer/1.2")
.buildUpon()
.appendQueryParameter("file", THREED_MODEL_URL)
.build()
sceneViewerIntent.setDataAndType(intentUri, MIME_TYPE)
startActivity(sceneViewerIntent)
দৃশ্য দর্শকের জন্য ইন্টারঅ্যাক্টিভিটি বিকল্প সম্পর্কে আরও তথ্যের জন্য, আমাদের 3D মডেল ডিজাইন ডকুমেন্টেশন পড়ুন।
glTF এক্সটেনশন
Jetpack XR SDK বেশ কয়েকটি gfTF এক্সটেনশন সমর্থন করে যা 3D মডেলের ক্ষমতা প্রসারিত করে। এই ক্ষমতাগুলি GltfEntity
এবং দৃশ্য দর্শক উভয়ের মাধ্যমেই পাওয়া যায়।
-
KHR_animation_pointer
-
KHR_draco_mesh_compression
-
KHR_lights_punctual
-
KHR_materials_clearcoat
-
KHR_materials_sheen
-
KHR_materials_unlit
-
KHR_materials_variants
-
KHR_mesh_quantization
-
KHR_texture_basisu
-
KHR_texture_transform
-
EXT_texture_webp