জিওস্পেশিয়াল অ্যাঙ্কর হল এক ধরনের অ্যাঙ্কর যা আপনাকে বাস্তব জগতে 3D সামগ্রী রাখতে দেয়।
ভূ-স্থানিক অ্যাঙ্করগুলির প্রকারভেদ
তিন ধরনের জিওস্পেশিয়াল অ্যাঙ্কর রয়েছে, যেগুলো প্রত্যেকটি উচ্চতাকে ভিন্নভাবে পরিচালনা করে:
WGS84 অ্যাঙ্কর :
WGS84 অ্যাঙ্কর আপনাকে যে কোনো অক্ষাংশ, দ্রাঘিমাংশ এবং উচ্চতায় 3D সামগ্রী রাখতে দেয়।ভূখণ্ড নোঙ্গর :
ভূখণ্ড অ্যাঙ্করগুলি আপনাকে সেই অবস্থানে ভূখণ্ডের সাথে সম্পর্কিত উচ্চতা সহ শুধুমাত্র অক্ষাংশ এবং দ্রাঘিমাংশ ব্যবহার করে সামগ্রী রাখতে দেয়৷ উচ্চতা ভিপিএস দ্বারা পরিচিত স্থল বা তল সাপেক্ষে নির্ধারিত হয়।ছাদের নোঙ্গর :
ছাদের নোঙ্গরগুলি আপনাকে সেই অবস্থানে একটি বিল্ডিংয়ের ছাদের তুলনায় উচ্চতার সাথে শুধুমাত্র অক্ষাংশ এবং দ্রাঘিমাংশ ব্যবহার করে সামগ্রী রাখতে দেয়৷ স্ট্রিটস্কেপ জ্যামিতি দ্বারা পরিচিত একটি বিল্ডিংয়ের শীর্ষের সাপেক্ষে উচ্চতা নির্ধারণ করা হয়। এটি ভূখণ্ডের উচ্চতায় ডিফল্ট হবে যখন একটি বিল্ডিংয়ে স্থাপন করা হবে না।
WGS84 | ভূখণ্ড | ছাদ | |
---|---|---|---|
অনুভূমিক অবস্থান | অক্ষাংশ, দ্রাঘিমাংশ | অক্ষাংশ, দ্রাঘিমাংশ | অক্ষাংশ, দ্রাঘিমাংশ |
উল্লম্ব অবস্থান | WGS84 উচ্চতার সাথে আপেক্ষিক | Google মানচিত্র দ্বারা নির্ধারিত ভূখণ্ড স্তরের সাথে সম্পর্কিত | Google মানচিত্র দ্বারা নির্ধারিত ছাদের স্তরের সাথে সম্পর্কিত৷ |
সার্ভার-সমাধান করা প্রয়োজন? | না | হ্যাঁ | হ্যাঁ |
পূর্বশর্ত
এগিয়ে যাওয়ার আগে নিশ্চিত করুন যে আপনি ভূ-স্থানীয় API সক্ষম করেছেন ৷
ভূ-স্থানিক নোঙ্গর রাখুন
প্রতিটি অ্যাঙ্কর টাইপ তাদের তৈরি করতে উত্সর্গীকৃত API আছে; আরও তথ্যের জন্য জিওস্পেশিয়াল অ্যাঙ্করগুলির প্রকারগুলি দেখুন৷
একটি হিট-পরীক্ষা থেকে একটি অ্যাঙ্কর তৈরি করুন
আপনি একটি হিট-পরীক্ষার ফলাফল থেকে একটি ভূ-স্থানীয় অ্যাঙ্করও তৈরি করতে পারেন। হিট-টেস্ট থেকে ভঙ্গিটি ব্যবহার করুন এবং এটিকে একটি GeospatialPose
রূপান্তর করুন। বর্ণিত 3টি অ্যাঙ্কর প্রকারের যে কোনো স্থাপন করতে এটি ব্যবহার করুন।
একটি এআর পোজ থেকে একটি ভূ-স্থানিক ভঙ্গি পান
AREarthManager.Convert(Pose)
একটি এআর পোজকে একটি ভূ-স্থানিক ভঙ্গিতে রূপান্তর করে অক্ষাংশ এবং দ্রাঘিমাংশ নির্ধারণ করার একটি অতিরিক্ত উপায় প্রদান করে।
একটি ভূ-স্থানিক ভঙ্গি থেকে একটি এআর পোজ পান
AREarthManager.Convert(GeospatialPose)
GL ওয়ার্ল্ড কোঅর্ডিনেটের সাপেক্ষে একটি পূর্ব-উপ-দক্ষিণ স্থানাঙ্ক ফ্রেমের সাপেক্ষে একটি পৃথিবী-নির্দিষ্ট অনুভূমিক অবস্থান, উচ্চতা এবং চতুর্ভুজ ঘূর্ণনকে একটি এআর পোজে রূপান্তরিত করে।
আপনার ব্যবহারের ক্ষেত্রে কোন পদ্ধতি উপযুক্ত তা চয়ন করুন
একটি অ্যাঙ্কর তৈরির প্রতিটি পদ্ধতি মনে রাখতে সংশ্লিষ্ট ট্রেডঅফ রয়েছে:
- স্ট্রিটস্কেপ জ্যামিতি ব্যবহার করার সময়, একটি বিল্ডিং এর সাথে বিষয়বস্তু সংযুক্ত করতে একটি হিট-টেস্ট ব্যবহার করুন৷
- WGS84 অ্যাঙ্করগুলির চেয়ে ভূখণ্ড বা ছাদের নোঙ্গরগুলি পছন্দ করুন কারণ তারা Google মানচিত্র দ্বারা নির্ধারিত উচ্চতা মান ব্যবহার করে৷
একটি অবস্থানের অক্ষাংশ এবং দ্রাঘিমাংশ নির্ধারণ করুন
তিনটি উপায়ে আপনি একটি অবস্থানের অক্ষাংশ এবং দ্রাঘিমাংশ গণনা করতে পারেন:
- শারীরিকভাবে কোনো অবস্থানে না গিয়ে 3D বিষয়বস্তু সহ বিশ্বকে দেখতে এবং বৃদ্ধি করতে ভূ-স্থানীয় সৃষ্টিকর্তা ব্যবহার করুন। এটি আপনাকে ইউনিটি এডিটরে Google মানচিত্র ব্যবহার করে দৃশ্যত 3D নিমজ্জিত সামগ্রী রাখতে দেয়। বিষয়বস্তুর অক্ষাংশ, দ্রাঘিমাংশ, ঘূর্ণন এবং উচ্চতা স্বয়ংক্রিয়ভাবে আপনার জন্য গণনা করা হবে।
- গুগল ম্যাপ ব্যবহার করুন
- গুগল আর্থ ব্যবহার করুন। মনে রাখবেন যে Google আর্থ ব্যবহার করে এই স্থানাঙ্কগুলি প্রাপ্ত করা, Google মানচিত্রের বিপরীতে, আপনাকে কয়েক মিটার পর্যন্ত একটি ত্রুটি মার্জিন দেবে৷
- শারীরিক অবস্থানে যান
গুগল ম্যাপ ব্যবহার করুন
Google মানচিত্র ব্যবহার করে একটি অবস্থানের অক্ষাংশ এবং দ্রাঘিমাংশ পেতে:
আপনার ডেস্কটপ কম্পিউটারে গুগল ম্যাপে যান।
লেয়ার > আরও -এ নেভিগেট করুন।
স্যাটেলাইটে মানচিত্রের ধরন পরিবর্তন করুন এবং স্ক্রিনের নীচে বাম কোণে গ্লোব ভিউ চেকবক্সটি সাফ করুন।
এটি একটি 2D দৃষ্টিকোণকে জোর করবে এবং একটি কোণীয় 3D দৃশ্য থেকে আসা সম্ভাব্য ত্রুটিগুলি দূর করবে৷
মানচিত্রে, অবস্থানের উপর ডান-ক্লিক করুন এবং আপনার ক্লিপবোর্ডে অনুলিপি করতে দ্রাঘিমাংশ/অক্ষাংশ নির্বাচন করুন।
গুগল আর্থ ব্যবহার করুন
আপনি UI-তে একটি অবস্থানে ক্লিক করে এবং স্থানচিহ্নের বিবরণ থেকে ডেটা পড়ে Google আর্থ থেকে একটি অবস্থানের অক্ষাংশ এবং দ্রাঘিমাংশ গণনা করতে পারেন।
গুগল আর্থ ব্যবহার করে একটি অবস্থানের অক্ষাংশ এবং দ্রাঘিমাংশ পেতে:
আপনার ডেস্কটপ কম্পিউটারে Google Earth এ যান।
হ্যামবার্গার মেনুতে নেভিগেট করুন এবং মানচিত্র শৈলী নির্বাচন করুন।
3D বিল্ডিং সুইচ বন্ধ করুন।
একবার 3D বিল্ডিং সুইচ টগল অফ হয়ে গেলে, পিন আইকনে ক্লিক করুন নির্বাচিত স্থানে একটি স্থানচিহ্ন যোগ করতে।
আপনার স্থানচিহ্ন ধারণ করার জন্য একটি প্রকল্প নির্দিষ্ট করুন এবং সংরক্ষণ করুন ক্লিক করুন।
স্থানচিহ্নের জন্য শিরোনাম ক্ষেত্রে, স্থানচিহ্নের জন্য একটি নাম লিখুন।
পিছনের তীরটিতে ক্লিক করুন প্রকল্প ফলকে এবং নির্বাচন করুন আরও অ্যাকশন মেনু।
মেনু থেকে KML ফাইল হিসাবে রপ্তানি নির্বাচন করুন।
KLM ফাইলটি কমা দ্বারা পৃথক করা <coordinates>
ট্যাগে একটি স্থানচিহ্নের জন্য অক্ষাংশ, দ্রাঘিমাংশ এবং উচ্চতা রিপোর্ট করে, নিম্নরূপ:
<coordinates>-122.0755182435043,37.41347299422944,7.420342565583832</coordinates>
<LookAt>
ট্যাগগুলি থেকে অক্ষাংশ এবং দ্রাঘিমাংশ ব্যবহার করবেন না , যা ক্যামেরা অবস্থান নির্দিষ্ট করে, অবস্থান নয়।
শারীরিক অবস্থানে যান
আপনি সেখানে শারীরিকভাবে গিয়ে এবং স্থানীয় পর্যবেক্ষণ করে একটি অবস্থানের উচ্চতা গণনা করতে পারেন।
ঘূর্ণন quaternion পান
GeospatialPose.EunRotation
একটি ভূ-স্থানিক ভঙ্গি থেকে ওরিয়েন্টেশন বের করে এবং একটি চতুর্ভুজ বের করে যা ঘূর্ণন ম্যাট্রিক্সকে প্রতিনিধিত্ব করে যা একটি ভেক্টরকে লক্ষ্য থেকে পূর্ব-উত্তর (EUN) স্থানাঙ্ক সিস্টেমে রূপান্তর করে। X+ পয়েন্ট পূর্বে, Y+ মাধ্যাকর্ষণ থেকে দূরে এবং Z+ পয়েন্ট উত্তরে।
WGS84 অ্যাঙ্কর
একটি WGS84 অ্যাঙ্কর হল এক ধরনের অ্যাঙ্কর যা আপনাকে যেকোন অক্ষাংশ, দ্রাঘিমাংশ এবং উচ্চতায় 3D সামগ্রী রাখতে দেয়। এটি বাস্তব জগতে স্থাপন করার জন্য একটি ভঙ্গি এবং অভিযোজনের উপর নির্ভর করে। অবস্থানটি একটি অক্ষাংশ, দ্রাঘিমাংশ এবং উচ্চতা নিয়ে গঠিত, যা WGS84 স্থানাঙ্ক সিস্টেমে নির্দিষ্ট করা হয়েছে। স্থিতিবিন্যাস একটি quaternion ঘূর্ণন গঠিত.
উচ্চতা রেফারেন্স WGS84 উপবৃত্তাকার উপরে মিটারে রিপোর্ট করা হয়েছে এমন যে স্থল স্তর শূন্য নয় । আপনার অ্যাপ প্রতিটি তৈরি অ্যাঙ্করের জন্য এই স্থানাঙ্কগুলি প্রদানের জন্য দায়ী৷
বাস্তব জগতে একটি WGS84 অ্যাঙ্কর রাখুন
একটি অবস্থানের উচ্চতা নির্ধারণ করুন
অ্যাঙ্কর স্থাপনের জন্য একটি অবস্থানের উচ্চতা নির্ধারণ করার কয়েকটি উপায় রয়েছে:
- যদি অ্যাঙ্করের অবস্থান শারীরিকভাবে ব্যবহারকারীর কাছাকাছি থাকে, তাহলে আপনি একটি উচ্চতা ব্যবহার করতে পারেন যা ব্যবহারকারীর ডিভাইসের উচ্চতার মতো।
- একবার আপনার অক্ষাংশ এবং দ্রাঘিমাংশ পেয়ে গেলে, EGM96 স্পেসিফিকেশনের উপর ভিত্তি করে একটি উচ্চতা পেতে Elevation API ব্যবহার করুন।
GeospatialPose
উচ্চতার সাথে তুলনা করার জন্য আপনাকে অবশ্যই Maps API EGM96 উচ্চতাকে WGS84 তে রূপান্তর করতে হবে। GeoidEval দেখুন যেটিতে একটি কমান্ড লাইন এবং একটি HTML ইন্টারফেস উভয়ই রয়েছে। মানচিত্র API বাক্সের বাইরে WGS84 স্পেসিফিকেশন অনুযায়ী অক্ষাংশ এবং দ্রাঘিমাংশ রিপোর্ট করে। - আপনি Google আর্থ থেকে একটি অবস্থানের অক্ষাংশ, দ্রাঘিমাংশ এবং উচ্চতা পেতে পারেন। এটি আপনাকে কয়েক মিটার পর্যন্ত একটি ত্রুটি মার্জিন দেবে। KML ফাইলে
<coordinates>
ট্যাগগুলি থেকে অক্ষাংশ, দ্রাঘিমাংশ এবং উচ্চতা ব্যবহার করুন,<LookAt>
ট্যাগগুলি নয় । - যদি একটি বিদ্যমান অ্যাঙ্কর কাছাকাছি থাকে এবং আপনি যদি খাড়া বাঁকের উপর না থাকেন, তাহলে আপনি ম্যাপ এপিআই-এর মতো অন্য কোনো উৎস ব্যবহার না করেই ক্যামেরার
GeospatialPose
থেকে উচ্চতা ব্যবহার করতে পারবেন।
অ্যাঙ্কর তৈরি করুন
একবার আপনার অক্ষাংশ, দ্রাঘিমাংশ, উচ্চতা এবং ঘূর্ণন চতুর্ভুজ হয়ে গেলে, আপনার নির্দিষ্ট করা ভৌগলিক স্থানাঙ্কে সামগ্রী নোঙ্গর করতে ARAnchorManagerExtensions.AddAnchor()
ব্যবহার করুন।
if (earthTrackingState == TrackingState.Tracking)
{
var anchor =
AnchorManager.AddAnchor(
latitude,
longitude,
altitude,
quaternion);
var anchoredAsset = Instantiate(GeospatialAssetPrefab, anchor.transform);
}
ভূখণ্ড অ্যাঙ্কর
একটি ভূখণ্ড অ্যাঙ্কর হল এক ধরনের অ্যাঙ্কর যা আপনাকে শুধুমাত্র অক্ষাংশ এবং দ্রাঘিমাংশ ব্যবহার করে এআর অবজেক্ট স্থাপন করতে দেয়, ভিপিএস থেকে তথ্য ব্যবহার করে মাটির উপরে সুনির্দিষ্ট উচ্চতা খুঁজে বের করতে।
পছন্দসই উচ্চতা ইনপুট করার পরিবর্তে, আপনি ভূখণ্ডের উপরে উচ্চতা প্রদান করেন। যখন এটি শূন্য হয় তখন নোঙ্গরটি ভূখণ্ডের সাথে সমান হবে।
প্লেন-ফাইন্ডিং মোড সেট করুন
প্লেন ফাইন্ডিং ঐচ্ছিক এবং অ্যাঙ্কর ব্যবহার করার প্রয়োজন নেই। উল্লেখ্য যে শুধুমাত্র অনুভূমিক সমতল ব্যবহার করা হয়। অনুভূমিক সমতলগুলি মাটিতে ভূখণ্ডের নোঙ্গরগুলির গতিশীল প্রান্তিককরণে সহায়তা করবে।
মনে রাখবেন যে ভূখণ্ড নোঙ্গরগুলি Horizontal
এবং Horizontal | Vertical
দ্বারা প্রভাবিত হয়৷ Horizontal | Vertical
সনাক্তকরণ মোড সেট করতে সনাক্তকরণ মোড ড্রপ-ডাউন মেনু ব্যবহার করুন:
নতুন Async API ব্যবহার করে একটি ভূখণ্ড অ্যাঙ্কর তৈরি করুন
একটি ভূখণ্ড অ্যাঙ্কর তৈরি করতে এবং স্থাপন করতে, ARAnchorManagerExtensions.resolveAnchorOnTerrainAsync()
কল করুন।
অ্যাঙ্কর এখনই প্রস্তুত হবে না এবং সমাধান করতে হবে। এটি সমাধান হয়ে গেলে এটি ResolveAnchorOnTerrainPromise
এ উপলব্ধ হবে।
public GameObject TerrainAnchorPrefab;
public void Update()
{
ResolveAnchorOnTerrainPromise terrainPromise =
AnchorManager.ResolveAnchorOnTerrainAsync(
latitude, longitude, altitudeAboveTerrain, eunRotation);
// The anchor will need to be resolved.
StartCoroutine(CheckTerrainPromise(terrainPromise));
}
private IEnumerator CheckTerrainPromise(ResolveAnchorOnTerrainPromise promise)
{
yield return promise;
var result = promise.Result;
if (result.TerrainAnchorState == TerrainAnchorState.Success &&
result.Anchor != null)
{
// resolving anchor succeeded
GameObject anchorGO = Instantiate(TerrainAnchorPrefab,
result.Anchor.gameObject.transform);
anchorGO.transform.parent = result.Anchor.gameObject.transform;
}
else
{
// resolving anchor failed
}
yield break;
}
প্রতিশ্রুতির অবস্থা পরীক্ষা করুন
প্রতিশ্রুতির একটি যুক্ত PromiseState
থাকবে।
রাজ্য | বর্ণনা |
---|---|
Pending | অপারেশন এখনো বাকি আছে। |
Done | অপারেশন সম্পূর্ণ এবং ফলাফল পাওয়া যায়. |
Cancelled | অপারেশন বাতিল করা হয়েছে। |
প্রতিশ্রুতি ফলাফলের ভূখণ্ড অ্যাঙ্কর অবস্থা পরীক্ষা করুন
TerrainAnchorState
অ্যাসিঙ্ক্রোনাস অপারেশনের অন্তর্গত এবং চূড়ান্ত প্রতিশ্রুতি ফলাফলের অংশ।
switch (result.TerrainAnchorState)
{
case TerrainAnchorState.Success:
// Anchor has successfully resolved
break;
case TerrainAnchorState.ErrorUnsupportedLocation:
// The requested anchor is in a location that isn't supported by the Geospatial API.
break;
case TerrainAnchorState.ErrorNotAuthorized:
// An error occurred while authorizing your app with the ARCore API. See
// https://developers.google.com/ar/reference/unity-arf/namespace/Google/XR/ARCoreExtensions#terrainanchorstate_errornotauthorized
// for troubleshooting steps.
break;
case TerrainAnchorState.ErrorInternal:
// The Terrain anchor could not be resolved due to an internal error.
break;
default:
break;
}
ছাদ নোঙ্গর
ছাদের নোঙ্গরগুলি হল এক ধরণের নোঙ্গর এবং উপরের ভূখণ্ডের অ্যাঙ্করগুলির সাথে খুব মিল। পার্থক্য হল আপনি ভূখণ্ডের উপরে উচ্চতার পরিবর্তে ছাদের উপরে উচ্চতা প্রদান করবেন।
নতুন Async API ব্যবহার করে একটি রুফটপ অ্যাঙ্কর তৈরি করুন
অ্যাঙ্কর এখনই প্রস্তুত হবে না এবং সমাধান করতে হবে।
একটি রুফটপ অ্যাঙ্কর তৈরি করতে এবং স্থাপন করতে, ARAnchorManagerExtensions.resolveAnchorOnRooftopAsync()
কল করুন। একইভাবে ভূখণ্ডের অ্যাঙ্করগুলির জন্য, আপনি প্রতিশ্রুতির PromiseState
অ্যাক্সেস পাবেন। তারপর আপনি RooftopAnchorState
অ্যাক্সেস করার জন্য প্রতিশ্রুতি ফলাফল পরীক্ষা করতে পারেন।
public GameObject RooftopAnchorPrefab;
public void Update()
{
ResolveAnchorOnRooftopPromise rooftopPromise =
AnchorManager.ResolveAnchorOnRooftopAsync(
latitude, longitude, altitudeAboveRooftop, eunRotation);
// The anchor will need to be resolved.
StartCoroutine(CheckRooftopPromise(rooftopPromise));
}
private IEnumerator CheckRooftopPromise(ResolveAnchorOnTerrainPromise promise)
{
yield return promise;
var result = promise.Result;
if (result.RooftopAnchorState == RooftopAnchorState.Success &&
result.Anchor != null)
{
// resolving anchor succeeded
GameObject anchorGO = Instantiate(RooftopAnchorPrefab,
result.Anchor.gameObject.transform);
anchorGO.transform.parent = result.Anchor.gameObject.transform;
}
else
{
// resolving anchor failed
}
yield break;
}
প্রতিশ্রুতির অবস্থা পরীক্ষা করুন
প্রতিশ্রুতিতে একটি যুক্ত PromiseState
থাকবে, উপরের টেবিলটি দেখুন।
প্রতিশ্রুতি ফলাফলের ছাদ নোঙ্গর অবস্থা পরীক্ষা করুন
RooftopAnchorState
অ্যাসিঙ্ক্রোনাস অপারেশনের অন্তর্গত এবং চূড়ান্ত প্রতিশ্রুতি ফলাফলের অংশ।
switch (result.RooftopAnchorState)
{
case TerrainAnchorState.Success:
// Anchor has successfully resolved
break;
case RooftopAnchorState.ErrorUnsupportedLocation:
// The requested anchor is in a location that isn't supported by the Geospatial API.
break;
case RooftopAnchorState.ErrorNotAuthorized:
// An error occurred while authorizing your app with the ARCore API. See
// https://developers.google.com/ar/reference/unity-arf/namespace/Google/XR/ARCoreExtensions#terrainanchorstate_errornotauthorized
// for troubleshooting steps.
break;
case RooftopAnchorState.ErrorInternal:
// The Rooftop anchor could not be resolved due to an internal error.
break;
default:
break;
}
এরপর কি
- নিশ্চিত করুন যে আপনি ভূ-স্থানীয় API ব্যবহার কোটা বুঝতে পেরেছেন।