با نحوه استفاده از Cloud Anchors در برنامه های خود آشنا شوید.
پیش نیازها
قبل از ادامه، مطمئن شوید که مفاهیم اساسی AR و نحوه پیکربندی یک جلسه ARCore را درک کرده اید.
اگر در Cloud Anchors تازه کار هستید:
- مطمئن شوید که نحوه کار لنگرها و Cloud Anchors را درک کرده اید.
- برای اطلاع از الزامات سیستم، راه اندازی و دستورالعمل های نصب ، راه اندازی سریع Cloud Anchors را بخوانید.
ARCore API را فعال کنید
قبل از استفاده از Cloud Anchors در برنامه خود، ابتدا باید ARCore API را در برنامه خود فعال کنید.
قابلیتهای Cloud Anchor را در پیکربندی جلسه فعال کنید
هنگامی که عملکرد Cloud Anchors در برنامه شما فعال شد، قابلیتهای Cloud Anchors را در پیکربندی جلسه AR برنامه خود فعال کنید تا بتواند با ARCore API ارتباط برقرار کند:
جاوا
Config config = new Config(session); config.setCloudAnchorMode(Config.CloudAnchorMode.ENABLED); session.configure(config);
کاتلین
val config = Config(session) config.cloudAnchorMode = Config.CloudAnchorMode.ENABLED session.configure(config)
میزبان یک Cloud Anchor
میزبانی با تماس با hostCloudAnchorAsync()
شروع می شود. ARCore داده های بصری، ژست های دستگاه و ژست لنگر را در ARCore API آپلود می کند. سپس API این اطلاعات را پردازش میکند تا یک نقشه ویژگی سهبعدی ایجاد کند، و در نهایت یک شناسه لنگر ابری منحصر به فرد برای لنگر به دستگاه برمیگرداند.
همچنین می توانید با استفاده از ARCore Cloud Anchor Management API طول عمر یک لنگر میزبان را افزایش دهید.
برنامه شما باید این مراحل را برای تکمیل میزبانی یک Cloud Anchor دنبال کند:
-
hostCloudAnchorAsync()
را فراخوانی کنید. - منتظر تماس باشید، یا به طور مداوم وضعیت آینده را بررسی کنید تا زمانی که انجام شود.
- وضعیت نتیجه را بررسی کنید تا مشخص شود آیا عملیات موفقیت آمیز بوده است یا اینکه در صورت عدم موفقیت، کد خطا را تفسیر کنید.
- شناسه Cloud Anchor نتیجه را با سایر کلاینتها به اشتراک بگذارید و از آن برای حل کردن Cloud Anchor با
resolveCloudAnchorAsync()
استفاده کنید.
کیفیت نقشه برداری نقاط ویژگی را بررسی کنید
Session.FeatureMapQuality
کیفیت نقاط مشخصه ای را نشان می دهد که توسط ARCore در چند ثانیه قبل از یک حالت دوربین مشخص دیده می شود. لنگرهای ابری که با استفاده از ویژگیهای با کیفیت بالاتر میزبانی میشوند، عموماً با دقت بیشتری حل میشوند. از Session.estimateFeatureMapQualityForHosting()
برای به دست آوردن تخمینی برای کیفیت نقشه ویژگی برای یک ژست دوربین معین استفاده کنید.
ارزش | توضیحات |
---|---|
INSUFFICIENT | کیفیت نقاط مشخصه مشخص شده از ژست در چند ثانیه قبل پایین است. این حالت نشان میدهد که ARCore احتمالاً در حل Cloud Anchor با مشکلات بیشتری مواجه خواهد شد. کاربر را تشویق کنید تا دستگاه را حرکت دهد تا موقعیت دلخواه Cloud Anchor که میخواهد میزبانی کند، از زوایای مختلف قابل مشاهده باشد. |
SUFFICIENT | کیفیت نقاط مشخصه مشخص شده از حالت در چند ثانیه قبل احتمالاً برای ARCore برای حل موفقیت آمیز یک Cloud Anchor کافی است، اگرچه دقت پوزیشن حل شده احتمالاً کاهش می یابد. کاربر را تشویق کنید تا دستگاه را حرکت دهد تا موقعیت دلخواه Cloud Anchor که میخواهد میزبانی کند، از زوایای مختلف قابل مشاهده باشد. |
GOOD | کیفیت نقاط مشخصه مشخص شده از پوز در چند ثانیه قبل احتمالاً برای ARCore کافی است تا بتواند یک Cloud Anchor را با درجه بالایی از دقت حل کند. |
لنگر میزبانی شده قبلی را حل کنید
برای حل و فصل یک Cloud Anchor میزبانی شده resolveCloudAnchorAsync()
را فراخوانی کنید. ARCore API به صورت دوره ای ویژگی های بصری صحنه را با نقشه ویژگی سه بعدی لنگر مقایسه می کند تا موقعیت و جهت گیری کاربر را نسبت به لنگر مشخص کند. هنگامی که API یک تطابق پیدا کرد، حالت Cloud Anchor میزبانی شده را برمیگرداند.
میتوانید حلوفصل چندین Cloud Anchors را به ترتیب آغاز کنید. حداکثر 40 عملیات Cloud Anchor میتواند در یک زمان وجود داشته باشد.
یک عملیات را لغو کنید یا یک Cloud Anchor را حذف کنید
برای لغو عملیات Cloud Anchor در حال انتظار cancel()
فراخوانی کنید. برای حذف یک Cloud Anchor از قبل حل شده از برنامه detach()
فراخوانی کنید.
وضعیت نتیجه عملیات Cloud Anchor را بررسی کنید
از Anchor.CloudAnchorState برای بررسی وضعیت نتیجه میزبانی یا عملیات حل، از جمله خطاها استفاده کنید.
ارزش | توضیحات |
---|---|
ERROR_CLOUD_ID_NOT_FOUND | حل نشد زیرا ARCore API نتوانست شناسه Cloud Anchor ارائه شده را پیدا کند. |
ERROR_HOSTING_DATASET_PROCESSING_FAILED | میزبانی انجام نشد زیرا سرور نتوانست مجموعه داده را برای لنگر داده شده با موفقیت پردازش کند. بعد از اینکه دستگاه اطلاعات بیشتری از محیط جمع آوری کرد، دوباره امتحان کنید. |
ERROR_HOSTING_SERVICE_UNAVAILABLE | ARCore API غیرقابل دسترسی بود. این ممکن است به دلایل مختلفی اتفاق بیفتد. ممکن است دستگاه در حالت هواپیما باشد یا اتصال اینترنت کار نمی کند. درخواست ارسال شده به سرور ممکن است بدون پاسخ به پایان رسیده باشد. ممکن است اتصال شبکه بد، در دسترس نبودن DNS، مشکلات فایروال یا هر چیز دیگری که ممکن است بر توانایی دستگاه برای اتصال به ARCore API تأثیر بگذارد، وجود داشته باشد. |
ERROR_INTERNAL | یک کار میزبانی یا حل برای این لنگر با یک خطای داخلی به پایان رسید. برنامه نباید سعی کند از این خطا بازیابی کند. |
ERROR_NOT_AUTHORIZED | مجوز ارائه شده توسط برنامه معتبر نیست. عیب یابی مجوز ARCore API را ببینید. |
ERROR_RESOLVING_SDK_VERSION_TOO_NEW | Cloud Anchor قابل حل نیست زیرا نسخه SDK مورد استفاده برای حل انکر جدیدتر از نسخه استفاده شده برای میزبانی آن است و با آن ناسازگار است. |
ERROR_RESOLVING_SDK_VERSION_TOO_OLD | Cloud Anchor قابل حل نیست زیرا نسخه SDK مورد استفاده برای حل انکر قدیمی تر از نسخه استفاده شده برای میزبانی آن است و با آن ناسازگار است. |
ERROR_RESOURCE_EXHAUSTED | برنامه سهمیه درخواست اختصاص داده شده به پروژه Google Cloud داده شده را تمام کرده است. شما باید سهمیه اضافی برای ARCore API برای پروژه خود را از Google Developers Console درخواست کنید. |
SUCCESS | یک کار میزبانی یا حل و فصل برای این لنگر با موفقیت انجام شد. |
سهمیه های API برای درخواست هاست و حل و فصل
ARCore API دارای سهمیه های زیر برای پهنای باند درخواست است:
نوع سهمیه | حداکثر | مدت زمان | اعمال می شود |
---|---|---|---|
تعداد لنگرها | نامحدود | N/A | پروژه |
درخواست های میزبان لنگر | 30 | دقیقه | آدرس IP و پروژه |
لنگر حل و فصل درخواست | 300 | دقیقه | آدرس IP و پروژه |
بهترین روش ها برای یک تجربه کاربری خوب
به کاربران دستور دهید تا برای اطمینان از تجربه کاربری خوب در برنامه خود، موارد زیر را انجام دهند:
- چند ثانیه بعد از شروع جلسه صبر کنید و قبل از اقدام به میزبانی لنگر (با قرار دادن یک شی و غیره) بمانید. این به ردیابی مدتی زمان برای تثبیت می دهد.
- هنگام انتخاب مکانی برای میزبانی لنگر، سعی کنید منطقه ای با ویژگی های بصری پیدا کنید که به راحتی از یکدیگر قابل تشخیص باشند. برای بهترین نتیجه، از سطوح بازتابنده یا سطوحی که فاقد ویژگی های بصری هستند، مانند دیوارهای سفید خالی اجتناب کنید.
دوربین را در مرکز مورد نظر آموزش دهید و دستگاه را در اطراف مرکز مورد نظر حرکت دهید تا از زوایای مختلف محیط را ترسیم کنید و تقریباً همان فاصله فیزیکی خود را حفظ کنید. این به گرفتن دادههای بصری بیشتر کمک میکند و حلوفصل را قویتر میکند.
هنگام میزبانی و حل و فصل Cloud Anchors اطمینان حاصل کنید که در محیط واقعی نور کافی وجود دارد.
سیاست استهلاک
- برنامههای ساخته شده با ARCore SDK 1.12.0 یا بالاتر تحت پوشش خطمشی لغو Cloud Anchor API هستند.
- برنامههای ساخته شده با ARCore SDK 1.11.0 یا پایینتر، به دلیل استفاده SDK از ARCore API قدیمیتر و منسوخ، قادر به میزبانی یا حل کردن Cloud Anchors نیستند.
بعدش چی
- یک برنامه Cloud Anchors با ARCore Cloud Anchors با کد لبه Cloud Anchors دائمی ایجاد کنید.
- از طریق دو برنامه نمونه در شروع سریع Cloud Anchors ، میزبانی و حل کردن Cloud Anchors را طی کنید.
- Cloud Anchors را خارج از برنامه ARCore خود با استفاده از Cloud Anchors Management API مدیریت کنید.
- برای راههای بیشتر استفاده از ARCore در برنامهتان ، اسناد مرجع Android را بررسی کنید.
با نحوه استفاده از Cloud Anchors در برنامه های خود آشنا شوید.
پیش نیازها
قبل از ادامه، مطمئن شوید که مفاهیم اساسی AR و نحوه پیکربندی یک جلسه ARCore را درک کرده اید.
اگر در Cloud Anchors تازه کار هستید:
- مطمئن شوید که نحوه کار لنگرها و Cloud Anchors را درک کرده اید.
- برای اطلاع از الزامات سیستم، راه اندازی و دستورالعمل های نصب ، راه اندازی سریع Cloud Anchors را بخوانید.
ARCore API را فعال کنید
قبل از استفاده از Cloud Anchors در برنامه خود، ابتدا باید ARCore API را در برنامه خود فعال کنید.
قابلیتهای Cloud Anchor را در پیکربندی جلسه فعال کنید
هنگامی که عملکرد Cloud Anchors در برنامه شما فعال شد، قابلیتهای Cloud Anchors را در پیکربندی جلسه AR برنامه خود فعال کنید تا بتواند با ARCore API ارتباط برقرار کند:
جاوا
Config config = new Config(session); config.setCloudAnchorMode(Config.CloudAnchorMode.ENABLED); session.configure(config);
کاتلین
val config = Config(session) config.cloudAnchorMode = Config.CloudAnchorMode.ENABLED session.configure(config)
میزبان یک Cloud Anchor
میزبانی با تماس با hostCloudAnchorAsync()
شروع می شود. ARCore داده های بصری، ژست های دستگاه و ژست لنگر را در ARCore API آپلود می کند. سپس API این اطلاعات را پردازش میکند تا یک نقشه ویژگی سهبعدی ایجاد کند، و در نهایت یک شناسه لنگر ابری منحصر به فرد برای لنگر به دستگاه برمیگرداند.
همچنین می توانید با استفاده از ARCore Cloud Anchor Management API طول عمر یک لنگر میزبان را افزایش دهید.
برنامه شما باید این مراحل را برای تکمیل میزبانی یک Cloud Anchor دنبال کند:
-
hostCloudAnchorAsync()
را فراخوانی کنید. - منتظر تماس باشید، یا به طور مداوم وضعیت آینده را بررسی کنید تا زمانی که انجام شود.
- وضعیت نتیجه را بررسی کنید تا مشخص شود آیا عملیات موفقیت آمیز بوده است یا اینکه در صورت عدم موفقیت، کد خطا را تفسیر کنید.
- شناسه Cloud Anchor نتیجه را با سایر کلاینتها به اشتراک بگذارید و از آن برای حل کردن Cloud Anchor با
resolveCloudAnchorAsync()
استفاده کنید.
کیفیت نقشه برداری نقاط ویژگی را بررسی کنید
Session.FeatureMapQuality
کیفیت نقاط مشخصه ای را نشان می دهد که توسط ARCore در چند ثانیه قبل از یک حالت دوربین مشخص دیده می شود. لنگرهای ابری که با استفاده از ویژگیهای با کیفیت بالاتر میزبانی میشوند، عموماً با دقت بیشتری حل میشوند. از Session.estimateFeatureMapQualityForHosting()
برای به دست آوردن تخمینی برای کیفیت نقشه ویژگی برای یک ژست دوربین معین استفاده کنید.
ارزش | توضیحات |
---|---|
INSUFFICIENT | کیفیت نقاط مشخصه مشخص شده از ژست در چند ثانیه قبل پایین است. این حالت نشان میدهد که ARCore احتمالاً در حل Cloud Anchor با مشکلات بیشتری مواجه خواهد شد. کاربر را تشویق کنید تا دستگاه را حرکت دهد تا موقعیت دلخواه Cloud Anchor که میخواهد میزبانی کند، از زوایای مختلف قابل مشاهده باشد. |
SUFFICIENT | کیفیت نقاط مشخصه مشخص شده از حالت در چند ثانیه قبل احتمالاً برای ARCore برای حل موفقیت آمیز یک Cloud Anchor کافی است، اگرچه دقت پوزیشن حل شده احتمالاً کاهش می یابد. کاربر را تشویق کنید تا دستگاه را حرکت دهد تا موقعیت دلخواه Cloud Anchor که میخواهد میزبانی کند، از زوایای مختلف قابل مشاهده باشد. |
GOOD | کیفیت نقاط مشخصه مشخص شده از پوز در چند ثانیه قبل احتمالاً برای ARCore کافی است تا بتواند یک Cloud Anchor را با درجه بالایی از دقت حل کند. |
لنگر میزبانی شده قبلی را حل کنید
برای حل و فصل یک Cloud Anchor میزبانی شده resolveCloudAnchorAsync()
را فراخوانی کنید. ARCore API به صورت دوره ای ویژگی های بصری صحنه را با نقشه ویژگی سه بعدی لنگر مقایسه می کند تا موقعیت و جهت گیری کاربر را نسبت به لنگر مشخص کند. هنگامی که API یک تطابق پیدا کرد، حالت Cloud Anchor میزبانی شده را برمیگرداند.
میتوانید حلوفصل چندین Cloud Anchors را به ترتیب آغاز کنید. حداکثر 40 عملیات Cloud Anchor میتواند در یک زمان وجود داشته باشد.
یک عملیات را لغو کنید یا یک Cloud Anchor را حذف کنید
برای لغو عملیات Cloud Anchor در حال انتظار cancel()
فراخوانی کنید. برای حذف یک Cloud Anchor از قبل حل شده از برنامه detach()
فراخوانی کنید.
وضعیت نتیجه عملیات Cloud Anchor را بررسی کنید
از Anchor.CloudAnchorState برای بررسی وضعیت نتیجه میزبانی یا عملیات حل، از جمله خطاها استفاده کنید.
ارزش | توضیحات |
---|---|
ERROR_CLOUD_ID_NOT_FOUND | حل نشد زیرا ARCore API نتوانست شناسه Cloud Anchor ارائه شده را پیدا کند. |
ERROR_HOSTING_DATASET_PROCESSING_FAILED | میزبانی انجام نشد زیرا سرور نتوانست مجموعه داده را برای لنگر داده شده با موفقیت پردازش کند. بعد از اینکه دستگاه اطلاعات بیشتری از محیط جمع آوری کرد، دوباره امتحان کنید. |
ERROR_HOSTING_SERVICE_UNAVAILABLE | ARCore API غیرقابل دسترسی بود. این ممکن است به دلایل مختلفی اتفاق بیفتد. ممکن است دستگاه در حالت هواپیما باشد یا اتصال اینترنت کار نمی کند. درخواست ارسال شده به سرور ممکن است بدون پاسخ به پایان رسیده باشد. ممکن است اتصال شبکه بد، در دسترس نبودن DNS، مشکلات فایروال یا هر چیز دیگری که ممکن است بر توانایی دستگاه برای اتصال به ARCore API تأثیر بگذارد، وجود داشته باشد. |
ERROR_INTERNAL | یک کار میزبانی یا حل برای این لنگر با یک خطای داخلی به پایان رسید. برنامه نباید سعی کند از این خطا بازیابی کند. |
ERROR_NOT_AUTHORIZED | مجوز ارائه شده توسط برنامه معتبر نیست. عیب یابی مجوز ARCore API را ببینید. |
ERROR_RESOLVING_SDK_VERSION_TOO_NEW | Cloud Anchor قابل حل نیست زیرا نسخه SDK مورد استفاده برای حل انکر جدیدتر از نسخه استفاده شده برای میزبانی آن است و با آن ناسازگار است. |
ERROR_RESOLVING_SDK_VERSION_TOO_OLD | Cloud Anchor قابل حل نیست زیرا نسخه SDK مورد استفاده برای حل انکر قدیمی تر از نسخه استفاده شده برای میزبانی آن است و با آن ناسازگار است. |
ERROR_RESOURCE_EXHAUSTED | برنامه سهمیه درخواست اختصاص داده شده به پروژه Google Cloud داده شده را تمام کرده است. شما باید سهمیه اضافی برای ARCore API برای پروژه خود را از Google Developers Console درخواست کنید. |
SUCCESS | یک کار میزبانی یا حل و فصل برای این لنگر با موفقیت انجام شد. |
سهمیه های API برای درخواست هاست و حل و فصل
ARCore API دارای سهمیه های زیر برای پهنای باند درخواست است:
نوع سهمیه | حداکثر | مدت زمان | اعمال می شود |
---|---|---|---|
تعداد لنگرها | نامحدود | N/A | پروژه |
درخواست های میزبان لنگر | 30 | دقیقه | آدرس IP و پروژه |
لنگر حل و فصل درخواست | 300 | دقیقه | آدرس IP و پروژه |
بهترین روش ها برای یک تجربه کاربری خوب
به کاربران دستور دهید تا برای اطمینان از تجربه کاربری خوب در برنامه خود، موارد زیر را انجام دهند:
- چند ثانیه بعد از شروع جلسه صبر کنید و قبل از اقدام به میزبانی لنگر (با قرار دادن یک شی و غیره) بمانید. این به ردیابی مدتی زمان برای تثبیت می دهد.
- هنگام انتخاب مکانی برای میزبانی لنگر، سعی کنید منطقه ای با ویژگی های بصری پیدا کنید که به راحتی از یکدیگر قابل تشخیص باشند. برای بهترین نتیجه، از سطوح بازتابنده یا سطوحی که فاقد ویژگی های بصری هستند، مانند دیوارهای سفید خالی اجتناب کنید.
دوربین را در مرکز مورد نظر آموزش دهید و دستگاه را در اطراف مرکز مورد نظر حرکت دهید تا از زوایای مختلف محیط را ترسیم کنید و تقریباً همان فاصله فیزیکی خود را حفظ کنید. این به گرفتن دادههای بصری بیشتر کمک میکند و حلوفصل را قویتر میکند.
هنگام میزبانی و حل و فصل Cloud Anchors اطمینان حاصل کنید که در محیط واقعی نور کافی وجود دارد.
سیاست استهلاک
- برنامههای ساخته شده با ARCore SDK 1.12.0 یا بالاتر تحت پوشش خطمشی لغو Cloud Anchor API هستند.
- برنامههای ساخته شده با ARCore SDK 1.11.0 یا پایینتر، به دلیل استفاده SDK از ARCore API قدیمیتر و منسوخ، قادر به میزبانی یا حل کردن Cloud Anchors نیستند.
بعدش چی
- یک برنامه Cloud Anchors با ARCore Cloud Anchors با کد لبه Cloud Anchors دائمی ایجاد کنید.
- از طریق دو برنامه نمونه در شروع سریع Cloud Anchors ، میزبانی و حل کردن Cloud Anchors را طی کنید.
- Cloud Anchors را خارج از برنامه ARCore خود با استفاده از Cloud Anchors Management API مدیریت کنید.
- برای راههای بیشتر استفاده از ARCore در برنامهتان ، اسناد مرجع Android را بررسی کنید.