ARCore অগমেন্টেড ছবি

ARCore অগমেন্টেড ছবি

এই কোডল্যাব সম্পর্কে

subjectমে ৯, ২০২৪-এ শেষবার আপডেট করা হয়েছে
account_circleKai Zhou-এর লেখা

1. ওভারভিউ

ARCore হল Android এ অগমেন্টেড রিয়েলিটি অ্যাপ তৈরি করার একটি প্ল্যাটফর্ম। অগমেন্টেড ইমেজ আপনাকে AR অ্যাপ তৈরি করার ক্ষমতা দেয় যা বাস্তব জগতে প্রাক-নিবন্ধিত 2D ছবি চিনতে পারে এবং তাদের উপরে ভার্চুয়াল কন্টেন্ট অ্যাঙ্কর করতে পারে।

এই কোডল্যাব আপনাকে একটি বিদ্যমান ARCore নমুনা অ্যাপ পরিবর্তন করার মাধ্যমে অগমেন্টেড ইমেজগুলিকে একত্রিত করার জন্য নির্দেশিত করে যা স্থানান্তরিত বা স্থির।

আপনি কি নির্মাণ করবেন

এই কোডল্যাবে, আপনি একটি পূর্ব-বিদ্যমান ARCore নমুনা অ্যাপ তৈরি করতে যাচ্ছেন। কোডল্যাবের শেষে, আপনার অ্যাপটি সক্ষম হবে:

  • একটি চিত্র লক্ষ্য সনাক্ত করুন এবং লক্ষ্যে একটি ভার্চুয়াল গোলকধাঁধা সংযুক্ত করুন
  • চলমান লক্ষ্য যতক্ষণ ক্যামেরার দৃশ্যে থাকে ততক্ষণ ট্র্যাক করুন

6bc6605df89de525.gif

আপনি কি এই প্রথম কোনো ARCore অ্যাপ তৈরি করছেন?

আপনি কি এই কোডল্যাবে নমুনা কোড লেখার পরিকল্পনা করছেন বা শুধু এই পৃষ্ঠাগুলি পড়তে চান?

আপনি কি শিখবেন

  • জাভাতে ARCore-এ অগমেন্টেড ইমেজ কীভাবে ব্যবহার করবেন
  • ARCore দ্বারা স্বীকৃত একটি চিত্রের ক্ষমতা কীভাবে পরিমাপ করা যায়
  • কিভাবে একটি ছবিতে একটি ভার্চুয়াল বিষয়বস্তু সংযুক্ত করবেন এবং এর গতিবিধি ট্র্যাক করবেন

পূর্বশর্ত

এই কোডল্যাবটি সম্পূর্ণ করতে আপনার নির্দিষ্ট হার্ডওয়্যার এবং সফ্টওয়্যার প্রয়োজন হবে।

হার্ডওয়্যার প্রয়োজনীয়তা

সফ্টওয়্যার প্রয়োজনীয়তা

  • ARCore APK 1.9.0 বা তার পরে। এই APK সাধারণত প্লে স্টোরের মাধ্যমে ডিভাইসে স্বয়ংক্রিয়ভাবে ইনস্টল করা হয়
  • অ্যান্ড্রয়েড স্টুডিও সহ একটি ডেভেলপমেন্ট মেশিন (v3.1 বা পরবর্তী)
  • ইন্টারনেটে অ্যাক্সেস, কারণ আপনাকে বিকাশের সময় লাইব্রেরিগুলি ডাউনলোড করতে হবে

এখন আপনি সবকিছু প্রস্তুত পেয়েছেন, চলুন শুরু করা যাক!

2. উন্নয়ন পরিবেশ সেট আপ করুন

SDK ডাউনলোড করুন

আমরা GitHub থেকে সর্বশেষ ARCore Android SDK ডাউনলোড করে শুরু করব। আপনার পছন্দের অবস্থানে এটি আনজিপ করুন। এই কোডল্যাবের জন্য, প্রাচীনতম SDK সংস্করণ হল 1.18.1। ফোল্ডারটিকে arcore-android-sdk-x.xx.x হিসাবে উল্লেখ করা হবে, সঠিক মানটি হবে আপনার ব্যবহার করা SDK-এর সংস্করণ।

অ্যান্ড্রয়েড স্টুডিও চালু করুন, এবং একটি বিদ্যমান অ্যান্ড্রয়েড স্টুডিও প্রকল্প খুলুন ক্লিক করুন।

5fbf2b21609187cc.png

এই আনজিপ ফোল্ডারে নেভিগেট করুন:

arcore-android-sdk-x.xx.x/samples/augmented_image_java

খুলুন ক্লিক করুন.

অ্যান্ড্রয়েড স্টুডিও প্রকল্পটি সিঙ্ক করা শেষ করার জন্য অপেক্ষা করুন। আপনার অ্যান্ড্রয়েড স্টুডিওতে প্রয়োজনীয় উপাদান না থাকলে, এটি Install missing platform and sync project সাথে ব্যর্থ হতে পারে। সমস্যা সমাধানের জন্য নির্দেশাবলী অনুসরণ করুন.

নমুনা অ্যাপ চালান

এখন যেহেতু আপনার কাছে একটি কাজ করা ARCore অ্যাপ প্রজেক্ট আছে, চলুন এটিকে একটি পরীক্ষা করা যাক।

আপনার ARCore ডিভাইসটিকে ডেভেলপমেন্ট মেশিনের সাথে সংযুক্ত করুন এবং ডিভাইসে ডিবাগ সংস্করণ চালানোর জন্য মেনু রান > রান 'অ্যাপ' ব্যবহার করুন। ডায়ালগে আপনাকে কোন ডিভাইস থেকে চালনা করা হবে তা চয়ন করতে অনুরোধ করে, সংযুক্ত ডিভাইসটি চয়ন করুন এবং ঠিক আছে ক্লিক করুন।

1aa2c6faa7ecdbd0.png

92e4c144a632b4ca.png

এই নমুনা প্রকল্প targetSdkVersion 28 ব্যবহার করে। আপনার যদি Failed to find Build Tools revision 28.0.3 মতো বিল্ড ত্রুটি থাকে, তাহলে প্রয়োজনীয় অ্যান্ড্রয়েড বিল্ড টুলস সংস্করণ ডাউনলোড এবং ইনস্টল করতে Android স্টুডিওতে বর্ণিত নির্দেশাবলী অনুসরণ করুন।

সবকিছু সফল হলে, নমুনা অ্যাপটি ডিভাইসে চালু হবে এবং অগমেন্টেড ইমেজকে ছবি ও ভিডিও তোলার অনুমতি দেওয়ার জন্য আপনাকে অনুরোধ করবে। অনুমতি দেওয়ার জন্য ALLOW এ আলতো চাপুন।

একটি নমুনা ইমেজ সঙ্গে পরীক্ষা

এখন আপনি আপনার বিকাশের পরিবেশ সেট আপ করেছেন, আপনি এটি দেখার জন্য একটি চিত্র দিয়ে অ্যাপটি পরীক্ষা করতে পারেন৷

অ্যান্ড্রয়েড স্টুডিওতে ফিরে, প্রজেক্ট উইন্ডোতে, অ্যাপ > সম্পদে নেভিগেট করুন এবং এটি খুলতে default.jpg ফাইলটিতে ডাবল-ক্লিক করুন।

9b333680e7b9f247.jpeg

আপনার ডিভাইসের ক্যামেরাটিকে স্ক্রিনে থাকা পৃথিবীর চিত্রের দিকে নির্দেশ করুন এবং আপনি যে ছবিটি স্ক্যান করছেন সেটি ক্রসহেয়ারে ফিট করতে নির্দেশাবলী অনুসরণ করুন।

ছবির উপরে একটি ইমেজ ফ্রেম ওভারলে হবে, যেমন:

999e05ed35964f6e.png

এরপরে, আমরা নমুনা অ্যাপে ছোটখাটো উন্নতি করব।

3. 2D ছবিতে একটি গোলকধাঁধা মডেল প্রদর্শন করুন

আপনি এটির উপরে একটি 3D মডেল প্রদর্শন করে অগমেন্টেড ইমেজগুলির সাথে খেলা শুরু করতে পারেন।

একটি 3D মডেল ডাউনলোড করুন

এই কোডল্যাবের জন্য আমরা ইভোলের " সার্কেল মেজ - গ্রীন " ব্যবহার করতে যাচ্ছি, এবং CC-BY 3.0 এর অধীনে লাইসেন্সপ্রাপ্ত। আমি এই কোডল্যাবের গিথুব সংগ্রহস্থলে এই 3D মডেলের একটি অনুলিপি সংরক্ষণ করেছি, যা আপনি এখানে খুঁজে পেতে পারেন।

মডেলটি ডাউনলোড করতে এবং এটিকে Android স্টুডিওতে অন্তর্ভুক্ত করতে এই পদক্ষেপগুলি অনুসরণ করুন৷

  1. এই কোডল্যাবের গিটহাব রিপোজিটরিতে নেভিগেট করুন, থার্ড_পার্টি ডিরেক্টরি
  2. GreenMaze_obj.zip-এ ক্লিক করুন এবং ডাউনলোড বোতামে ক্লিক করুন।

এটি GreenMaze_obj.zip নামে একটি ফাইল ডাউনলোড করে।

  1. অ্যান্ড্রয়েড স্টুডিওতে, অ্যাপ > সম্পদ > মডেলের অধীনে green-maze ডিরেক্টরি তৈরি করুন
  2. GreenMaze_obj.zip আনজিপ করুন এবং এই অবস্থানে সামগ্রী অনুলিপি করুন: arcore-android-sdk-x.xx.x/samples/augmented_image_java/app/src/main/assets/models/green-maze
  3. অ্যান্ড্রয়েড স্টুডিওতে, অ্যাপ > সম্পদ > মডেল > সবুজ ধাঁধাঁতে নেভিগেট করুন।

এই ফোল্ডারে দুটি ফাইল থাকা উচিত: GreenMaze.obj এবং GreenMaze.mtl

a1f33a2d2d407e03.png

গোলকধাঁধা মডেল রেন্ডার

বিদ্যমান 2D চিত্রের উপরে GreenMaze.obj 3D মডেল প্রদর্শন করতে এই পদক্ষেপগুলি অনুসরণ করুন৷

AugmentedImageRenderer.java এ, গোলকধাঁধা মডেলটি রেন্ডার করতে mazeRenderer নামে একটি সদস্য ভেরিয়েবল যোগ করুন। কারণ গোলকধাঁধাটি চিত্রের সাথে সংযুক্ত করা উচিত, এটি AugmentedImageRenderer ক্লাসের মধ্যে mazeRenderer রাখা বোধগম্য।

AugmentedImageRenderer.java

  // Add a member variable to hold the maze model.
 
private final ObjectRenderer mazeRenderer = new ObjectRenderer();

createOnGlThread() ফাংশনে, GreenMaze.obj লোড করুন। সরলতার জন্য, এর টেক্সচারের মতো একই ফ্রেম টেক্সচার ব্যবহার করুন।

AugmentedImageRenderer.java

  // Replace the definition of the createOnGlThread() function with the
 
// following code, which loads GreenMaze.obj.
 
public void createOnGlThread(Context context) throws IOException {

    mazeRenderer
.createOnGlThread(
        context
, "models/green-maze/GreenMaze.obj", "models/frame_base.png");
    mazeRenderer
.setMaterialProperties(0.0f, 3.5f, 1.0f, 6.0f);

 
}

নিচের সাথে draw() ফাংশনের সংজ্ঞা প্রতিস্থাপন করুন। এটি গোলকধাঁধাটির আকার সনাক্ত করা চিত্রের আকারের সাথে সামঞ্জস্য করে এবং এটিকে অন-স্ক্রীনে রেন্ডার করে।

AugmentedImageRenderer.java

  // Adjust size of detected image and render it on-screen
 
public void draw(
     
float[] viewMatrix,
     
float[] projectionMatrix,
     
AugmentedImage augmentedImage,
     
Anchor centerAnchor,
     
float[] colorCorrectionRgba) {
   
float[] tintColor =
        convertHexToColor
(TINT_COLORS_HEX[augmentedImage.getIndex() % TINT_COLORS_HEX.length]);

   
final float mazeEdgeSize = 492.65f; // Magic number of maze size
   
final float maxImageEdgeSize = Math.max(augmentedImage.getExtentX(), augmentedImage.getExtentZ()); // Get largest detected image edge size

   
Pose anchorPose = centerAnchor.getPose();

   
float mazeScaleFactor = maxImageEdgeSize / mazeEdgeSize; // scale to set Maze to image size
   
float[] modelMatrix = new float[16];

   
// OpenGL Matrix operation is in the order: Scale, rotation and Translation
   
// So the manual adjustment is after scale
   
// The 251.3f and 129.0f is magic number from the maze obj file
   
// You mustWe need to do this adjustment because the maze obj file
   
// is not centered around origin. Normally when you
   
// work with your own model, you don't have this problem.
   
Pose mazeModelLocalOffset = Pose.makeTranslation(
                               
-251.3f * mazeScaleFactor,
                               
0.0f,
                               
129.0f * mazeScaleFactor);
    anchorPose
.compose(mazeModelLocalOffset).toMatrix(modelMatrix, 0);
    mazeRenderer
.updateModelMatrix(modelMatrix, mazeScaleFactor, mazeScaleFactor/10.0f, mazeScaleFactor); // This line relies on a change in ObjectRenderer.updateModelMatrix later in this codelab.
    mazeRenderer
.draw(viewMatrix, projectionMatrix, colorCorrectionRgba, tintColor);
 
}

এখন, গোলকধাঁধাটি পৃথিবীর default.jpg ছবির উপরে প্রদর্শন করা উচিত।

দ্রষ্টব্য: যেহেতু এই নমুনা 3D মডেলের উপর আপনার সম্পূর্ণ নিয়ন্ত্রণ নেই, উপরের কোডটি কয়েকটি "জাদু" সংখ্যা ব্যবহার করে৷ গোলকধাঁধা মডেলের মাত্রা হল 492.65 x 120 x 492.65, কেন্দ্রে (251.3, 60, -129.0)। এর শীর্ষবিন্দুগুলির X, Y, এবং Z স্থানাঙ্কের মানের পরিসীমা হল যথাক্রমে [5.02, 497.67], [0, 120], এবং [-375.17, 117.25]। সুতরাং, গোলকধাঁধা মডেলের স্কেল হতে হবে image_size / 492.65mazeModelLocalOffset চালু করা হয়েছে কারণ গোলকধাঁধাটির 3D মডেল উৎপত্তির (0, 0, 0) চারপাশে কেন্দ্রীভূত নয়।

গোলকধাঁধাটির প্রাচীরটি ছবির উপরে মাপসই করার জন্য এখনও কিছুটা উঁচু। একটি হেল্পার ফাংশন আপডেট তৈরি করুন updateModelMatrix() যা X, Y, Z কে অসমভাবে স্কেল করতে পারে গোলকধাঁধাটির উচ্চতা 0.1 করে। দ্রষ্টব্য, আপনি বিদ্যমান updateModelMatrix(float[] modelMatrix, float scaleFactor) রাখতে হবে এবং একটি নতুন ফাংশন হিসাবে ওভারলোড updateModelMatrix(float[] modelMatrix, float scaleFactorX, float scaleFactorY, float scaleFactorZ) যুক্ত করতে হবে।

common/rendering/ObjectRenderer.java

// Scale X, Y, Z coordinates unevenly
public void updateModelMatrix(float[] modelMatrix, float scaleFactorX, float scaleFactorY, float scaleFactorZ) {
   
float[] scaleMatrix = new float[16];
   
Matrix.setIdentityM(scaleMatrix, 0);
    scaleMatrix
[0] = scaleFactorX;
    scaleMatrix
[5] = scaleFactorY;
    scaleMatrix
[10] = scaleFactorZ;
   
Matrix.multiplyMM(this.modelMatrix, 0, modelMatrix, 0, scaleMatrix, 0);
}

কোড চালান। গোলকধাঁধাটি এখন চিত্রের উপরে পুরোপুরি ফিট করা উচিত।

772cbe2a8baef3ba.png

4. গোলকধাঁধায় অ্যান্ডি যোগ করুন

এখন আপনার কাছে একটি গোলকধাঁধা আছে, এটির ভিতরে ঘুরতে একটি অক্ষর যোগ করুন। ARCore Android SDK-এ অন্তর্ভুক্ত andy.obj ফাইলটি ব্যবহার করুন। ছবির ফ্রেমের টেক্সচারটিকে এর টেক্সচার হিসাবে রাখুন, কারণ এটি ছবির উপরে রেন্ডার করা সবুজ গোলকধাঁধা থেকে আলাদা দেখায়।

AugmentedImageRenderer.java এ, অ্যান্ডি রেন্ডার করতে একটি ব্যক্তিগত ObjectRenderer যোগ করুন।

AugmentedImageRenderer.java

// Render for Andy
 
private final ObjectRenderer andyRenderer = new ObjectRenderer();

এরপর, createOnGlThread() এর শেষে andyRenderer আরম্ভ করুন।

AugmentedImageRenderer.java

public void createOnGlThread(Context context) throws IOException {

   
// Initialize andyRenderer
    andyRenderer
.createOnGlThread(
        context
, "models/andy.obj", "models/andy.png");
    andyRenderer
.setMaterialProperties(0.0f, 3.5f, 1.0f, 6.0f);
 
}

অবশেষে, draw() ফাংশন শেষে গোলকধাঁধার উপরে দাঁড়িয়ে অ্যান্ডি রেন্ডার করুন।

AugmentedImageRenderer.java

public void draw(
     
float[] viewMatrix,
     
float[] projectionMatrix,
     
AugmentedImage augmentedImage,
     
Anchor centerAnchor,
     
float[] colorCorrectionRgba) {


   
// Render Andy, standing on top of the maze
   
Pose andyModelLocalOffset = Pose.makeTranslation(
       
0.0f,
       
0.1f,
       
0.0f);
    anchorPose
.compose(andyModelLocalOffset).toMatrix(modelMatrix, 0);
    andyRenderer
.updateModelMatrix(modelMatrix, 0.05f); // 0.05f is a Magic number to scale
    andyRenderer
.draw(viewMatrix, projectionMatrix, colorCorrectionRgba, tintColor);

 
}

আপনার কোড চালান. আপনার দেখতে হবে অ্যান্ডি গোলকধাঁধার উপরে দাঁড়িয়ে আছে।

cb1e74569d7ace69.png

টার্গেট ইমেজ মান নির্ধারণ

ছবি চিনতে ARCore ভিজ্যুয়াল বৈশিষ্ট্যের উপর নির্ভর করে। মানের পার্থক্যের কারণে সব ছবি সহজে চেনা যায় না।

arcoreimg হল একটি কমান্ড-লাইন টুল যা আপনাকে একটি ছবি ARCore-এ কতটা স্বীকৃত হবে তা নির্ধারণ করতে দেয়। এটি 0 থেকে 100 এর মধ্যে একটি সংখ্যা আউটপুট করে, 100 সনাক্ত করা সবচেয়ে সহজ।

. এখানে একটি উদাহরণ:

arcore-android-sdk-x.xx.x/tools/arcoreimg/macos$
$
./arcoreimg  eval-img --input_image_path=/Users/username/maze.jpg
100

maze.jpg এর মান 100, তাই এটি সহজেই ARCore দ্বারা স্বীকৃত হয়।

5. ঐচ্ছিক: গোলকধাঁধায় অ্যান্ডি সরান

অবশেষে, আপনি অ্যান্ডিকে গোলকধাঁধায় সরাতে কিছু কোড যোগ করতে পারেন। উদাহরণস্বরূপ, পদার্থবিদ্যার সিমুলেশন পরিচালনা করতে ওপেন সোর্স ফিজিক্স ইঞ্জিন, jBullet ব্যবহার করুন। আপনি যদি এই অংশটি এড়িয়ে যান তবে এটি সম্পূর্ণ ভাল।

PhysicsController.java ডাউনলোড করুন এবং ডিরেক্টরিতে আপনার প্রকল্পে যোগ করুন

arcore-android-sdk-x.xx.x/samples/augmented_image_java/app/src/main/java/com/google/ar/core/examples/java/augmentedimage/

অ্যান্ড্রয়েড স্টুডিওতে, প্রোজেক্ট অ্যাসেট ডিরেক্টরিতে GreenMaze.obj যোগ করুন , যাতে রানটাইমে এটি লোড করা যায়। App > assets > models > green-maze থেকে app > assets থেকে GreenMaze.obj কপি করুন।

অ্যাপের build.gradle ফাইলে নিম্নলিখিত নির্ভরতা যোগ করুন।

app/build.gradle

    // jbullet library
    implementation
'cz.advel.jbullet:jbullet:20101010-1'

অ্যান্ডির বর্তমান ভঙ্গির অবস্থান সংরক্ষণ করতে একটি পরিবর্তনশীল andyPose সংজ্ঞায়িত করুন।

AugmentedImageRenderer.java

  // Create a new pose for the Andy
 
private Pose andyPose = Pose.IDENTITY;

নতুন andyPose ভেরিয়েবল ব্যবহার করে অ্যান্ডি রেন্ডার করতে AugmentedImageRenderer.java পরিবর্তন করুন।

AugmentedImageRenderer.java

public void draw(
     
float[] viewMatrix,
     
float[] projectionMatrix,
     
AugmentedImage augmentedImage,
     
Anchor centerAnchor,
     
float[] colorCorrectionRgba) {

   
// Use these code to replace previous code for rendering the Andy object
   
//
   
// Adjust the Andy's rendering position
   
// The Andy's pose is at the maze's vertex's coordinate
   
Pose andyPoseInImageSpace = Pose.makeTranslation(
        andyPose
.tx() * mazeScaleFactor,
        andyPose
.ty() * mazeScaleFactor,
        andyPose
.tz() * mazeScaleFactor);

    anchorPose
.compose(andyPoseInImageSpace).toMatrix(modelMatrix, 0);
    andyRenderer
.updateModelMatrix(modelMatrix, 0.05f);
    andyRenderer
.draw(viewMatrix, projectionMatrix, colorCorrectionRgba, tintColor);
 
}

অ্যান্ডি পোজ আপডেট পেতে একটি নতুন ইউটিলিটি ফাংশন, updateAndyPose() যোগ করুন।

AugmentedImageRenderer.java

  // Receive Andy pose updates
 
public void updateAndyPose(Pose pose) {
    andyPose
= pose;
 
}

AugmentedImageActivity.java এ, একটি PhysicsController অবজেক্ট তৈরি করুন যা JBullet ফিজিক্স ইঞ্জিন ব্যবহার করে সমস্ত পদার্থবিদ্যা-সম্পর্কিত ফাংশন পরিচালনা করে।

AugmentedImageActivity.java

import com.google.ar.core.Pose;

 
// Declare the PhysicsController object
 
private PhysicsController physicsController;

পদার্থবিদ্যা ইঞ্জিনে, আমরা আসলে অ্যান্ডির প্রতিনিধিত্ব করার জন্য একটি অনমনীয় বল ব্যবহার করি এবং বলের ভঙ্গি ব্যবহার করে অ্যান্ডির ভঙ্গি আপডেট করি। যখনই অ্যাপটি কোনো ছবিকে চিনবে তখনই পদার্থবিদ্যা আপডেট করতে PhysicsController কল করুন। বলটিকে বাস্তব জগতের মতো সরাতে, গোলকধাঁধায় বলটিকে সরানোর জন্য বাস্তব-বিশ্বের মাধ্যাকর্ষণ প্রয়োগ করুন।

AugmentedImageActivity.java

// Update the case clause for TRACKING to call PhysicsController
// whenever the app recognizes an image
 
private void drawAugmentedImages(

   
...

       
case TRACKING:
         
// Switch to UI Thread to update View
         
this.runOnUiThread(
             
new Runnable() {
               
@Override
               
public void run() {
                  fitToScanView
.setVisibility(View.GONE);
               
}
             
});

         
// Create a new anchor for newly found images
         
if (!augmentedImageMap.containsKey(augmentedImage.getIndex())) {
           
Anchor centerPoseAnchor = augmentedImage.createAnchor(augmentedImage.getCenterPose());
            augmentedImageMap
.put(
                augmentedImage
.getIndex(), Pair.create(augmentedImage, centerPoseAnchor));

            physicsController
= new PhysicsController(this);
         
} else {
           
Pose ballPose = physicsController.getBallPose();
            augmentedImageRenderer
.updateAndyPose(ballPose);


           
// Use real world gravity, (0, -10, 0), as gravity
           
// Convert to Physics world coordinate(maze mesh has to be static)
           
// Use the converted coordinate as a force to move the ball
           
Pose worldGravityPose = Pose.makeTranslation(0, -10f, 0);
           
Pose mazeGravityPose = augmentedImage.getCenterPose().inverse().compose(worldGravityPose);
           
float mazeGravity[] = mazeGravityPose.getTranslation();
            physicsController
.applyGravityToBall(mazeGravity);

            physicsController
.updatePhysics();
         
}
         
break;

অ্যাপটি চালান। আপনি যখন ছবিটি কাত করবেন তখন অ্যান্ডির এখন বাস্তবসম্মতভাবে ঘুরে বেড়ানো উচিত।

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

2f0df284705d3704.gif

তাই তো! গোলকধাঁধা মাধ্যমে অ্যান্ডি পেতে চেষ্টা মজা আছে. ইঙ্গিত: আপনি যখন টার্গেট ইমেজটি উপরের দিকে ধরে রাখেন তখন প্রস্থান খুঁজে পাওয়া সহজ।

6. অভিনন্দন

অভিনন্দন, আপনি এই কোডল্যাবের শেষে পৌঁছেছেন, এবং এইভাবে করেছেন:

  • একটি ARCore AugmentedImage Java নমুনা তৈরি এবং চালানো হয়েছে।
  • সঠিক স্কেলে, ছবিতে একটি গোলকধাঁধা মডেল প্রদর্শন করতে নমুনা আপডেট করা হয়েছে।
  • মজার কিছু করতে ছবির ভঙ্গি ব্যবহার করেছেন।

আপনি যদি সম্পূর্ণ কোডটি উল্লেখ করতে চান তবে আপনি এটি এখানে ডাউনলোড করতে পারেন।

আপনি এই কোডল্যাব করতে মজা আছে?

আপনি এই কোডল্যাব করতে দরকারী কিছু শিখেছি?

আপনি কি এই কোডল্যাবে অ্যাপ তৈরি সম্পূর্ণ করেছেন?

আপনি কি আগামী 6 মাসের মধ্যে একটি ARCore অ্যাপ তৈরি করার পরিকল্পনা করছেন?