এই নথিতে আপনি Android-এ যে মৌলিক NFC কাজগুলি করেন তার বর্ণনা দেয়৷ এটি ব্যাখ্যা করে যে কীভাবে এনএফসি ডেটা এনডিইএফ বার্তার আকারে পাঠাতে এবং গ্রহণ করতে হয় এবং এই বৈশিষ্ট্যগুলিকে সমর্থন করে এমন অ্যান্ড্রয়েড ফ্রেমওয়ার্ক এপিআইগুলি বর্ণনা করে৷ নন-এনডিইএফ ডেটা নিয়ে কাজ করার আলোচনা সহ আরও উন্নত বিষয়ের জন্য, অ্যাডভান্সড এনএফসি দেখুন।
একটি NFC ট্যাগ থেকে NDEF ডেটা পড়া ট্যাগ ডিসপ্যাচ সিস্টেমের সাথে পরিচালনা করা হয়, যা আবিষ্কৃত NFC ট্যাগগুলিকে বিশ্লেষণ করে, সঠিকভাবে ডেটা শ্রেণীবদ্ধ করে এবং শ্রেণীবদ্ধ ডেটাতে আগ্রহী এমন একটি অ্যাপ্লিকেশন শুরু করে। একটি অ্যাপ্লিকেশন যা স্ক্যান করা NFC ট্যাগ পরিচালনা করতে চায় একটি অভিপ্রায় ফিল্টার ঘোষণা করতে পারে এবং ডেটা পরিচালনা করার জন্য অনুরোধ করতে পারে।
ট্যাগ প্রেরণ সিস্টেম
Android-চালিত ডিভাইসগুলি সাধারণত NFC ট্যাগগুলি খুঁজতে থাকে যখন স্ক্রীনটি আনলক থাকে, যদি না ডিভাইসের সেটিংস মেনুতে NFC অক্ষম করা থাকে৷ যখন একটি অ্যান্ড্রয়েড-চালিত ডিভাইস একটি NFC ট্যাগ আবিষ্কার করে, তখন পছন্দসই আচরণটি হল ব্যবহারকারীকে কোন অ্যাপ্লিকেশন ব্যবহার করতে হবে তা জিজ্ঞাসা না করেই অভিপ্রায় পরিচালনা করা সবচেয়ে উপযুক্ত কার্যকলাপ। যেহেতু ডিভাইসগুলি খুব স্বল্প পরিসরে NFC ট্যাগগুলি স্ক্যান করে, এটি সম্ভবত ব্যবহারকারীদের ম্যানুয়ালি একটি ক্রিয়াকলাপ নির্বাচন করা তাদের ট্যাগ থেকে ডিভাইসটিকে দূরে সরাতে এবং সংযোগটি ভাঙতে বাধ্য করবে৷ শুধুমাত্র NFC ট্যাগগুলিকে পরিচালনা করার জন্য আপনার কার্যকলাপ বিকাশ করা উচিত যেগুলি আপনার কার্যকলাপের জন্য অ্যাক্টিভিটি চয়নকারীকে উপস্থিত হওয়া থেকে আটকাতে যত্নশীল।
এই লক্ষ্যে আপনাকে সাহায্য করার জন্য, Android একটি বিশেষ ট্যাগ ডিসপ্যাচ সিস্টেম সরবরাহ করে যা স্ক্যান করা NFC ট্যাগগুলি বিশ্লেষণ করে, সেগুলিকে পার্স করে এবং স্ক্যান করা ডেটাতে আগ্রহী এমন অ্যাপ্লিকেশনগুলি সনাক্ত করার চেষ্টা করে৷ এটি এটি করে:
- NFC ট্যাগ পার্স করা এবং MIME প্রকার বা একটি URI খুঁজে বের করা যা ট্যাগে ডেটা পেলোড সনাক্ত করে৷
- MIME প্রকার বা URI এবং পেলোডকে একটি অভিপ্রায়ে এনক্যাপসুলেট করা। NFC ট্যাগগুলিকে MIME প্রকার এবং URI-তে কীভাবে ম্যাপ করা হয় তাতে এই প্রথম দুটি ধাপ বর্ণনা করা হয়েছে।
- অভিপ্রায়ের উপর ভিত্তি করে একটি কার্যকলাপ শুরু করে। কীভাবে NFC ট্যাগগুলি অ্যাপ্লিকেশনগুলিতে পাঠানো হয় তাতে এটি বর্ণনা করা হয়েছে।
কিভাবে NFC ট্যাগগুলি MIME প্রকার এবং URI-তে ম্যাপ করা হয়
আপনি আপনার NFC অ্যাপ্লিকেশানগুলি লেখা শুরু করার আগে, বিভিন্ন ধরনের NFC ট্যাগ, ট্যাগ ডিসপ্যাচ সিস্টেম কীভাবে NFC ট্যাগগুলিকে পার্স করে এবং একটি NDEF বার্তা সনাক্ত করার সময় ট্যাগ ডিসপ্যাচ সিস্টেম যে বিশেষ কাজ করে তা বোঝা গুরুত্বপূর্ণ। এনএফসি ট্যাগগুলি প্রযুক্তির বিস্তৃত অ্যারেতে আসে এবং তাদের কাছে বিভিন্ন উপায়ে ডেটা লেখা থাকতে পারে। এনডিইএফ স্ট্যান্ডার্ডের জন্য অ্যান্ড্রয়েডের সর্বাধিক সমর্থন রয়েছে, যা NFC ফোরাম দ্বারা সংজ্ঞায়িত করা হয়েছে।
NDEF ডেটা একটি বার্তা ( NdefMessage
) এর ভিতরে এনক্যাপসুলেট করা হয় যাতে এক বা একাধিক রেকর্ড থাকে ( NdefRecord
)। আপনি যে ধরনের রেকর্ড তৈরি করতে চান তার স্পেসিফিকেশন অনুযায়ী প্রতিটি NDEF রেকর্ড অবশ্যই সুগঠিত হতে হবে। এছাড়াও Android অন্যান্য ধরনের ট্যাগ সমর্থন করে যেগুলিতে NDEF ডেটা নেই, যেগুলি আপনি android.nfc.tech
প্যাকেজের ক্লাসগুলি ব্যবহার করে কাজ করতে পারেন৷ এই প্রযুক্তিগুলি সম্পর্কে আরও জানতে, উন্নত NFC বিষয় দেখুন৷ এই অন্যান্য ধরণের ট্যাগের সাথে কাজ করার জন্য ট্যাগের সাথে যোগাযোগ করার জন্য আপনার নিজস্ব প্রোটোকল স্ট্যাক লেখা জড়িত, তাই আমরা বিকাশের সহজতার জন্য এবং Android-চালিত ডিভাইসগুলির জন্য সর্বাধিক সমর্থনের জন্য সম্ভব হলে NDEF ব্যবহার করার পরামর্শ দিই।
দ্রষ্টব্য: সম্পূর্ণ এনডিইএফ স্পেসিফিকেশন ডাউনলোড করতে, এনএফসি ফোরাম স্পেসিফিকেশন এবং অ্যাপ্লিকেশন ডকুমেন্টস সাইটে যান এবং কীভাবে এনডিইএফ রেকর্ড তৈরি করতে হয় তার উদাহরণের জন্য সাধারণ ধরনের এনডিইএফ রেকর্ড তৈরি করা দেখুন।
এখন যেহেতু আপনার NFC ট্যাগের কিছু ব্যাকগ্রাউন্ড আছে, নিম্নলিখিত বিভাগগুলি আরও বিস্তারিতভাবে বর্ণনা করে যে কীভাবে Android NDEF ফর্ম্যাট করা ট্যাগগুলি পরিচালনা করে। যখন একটি অ্যান্ড্রয়েড-চালিত ডিভাইস এনডিইএফ ফর্ম্যাট করা ডেটা সম্বলিত একটি এনএফসি ট্যাগ স্ক্যান করে, তখন এটি বার্তাটি পার্স করে এবং ডেটার MIME প্রকার বা URI সনাক্ত করার চেষ্টা করে। এটি করার জন্য, সিস্টেমটি NdefMessage
ভিতরের প্রথম NdefRecord
পড়ে তা নির্ধারণ করে কিভাবে সম্পূর্ণ NDEF বার্তাকে ব্যাখ্যা করতে হয় (একটি NDEF বার্তার একাধিক NDEF রেকর্ড থাকতে পারে)। একটি সুগঠিত NDEF বার্তায়, প্রথম NdefRecord
নিম্নলিখিত ক্ষেত্রগুলি রয়েছে:
- 3-বিট TNF (টাইপ নেম ফরম্যাট)
- পরিবর্তনশীল দৈর্ঘ্য টাইপ ক্ষেত্রকে কীভাবে ব্যাখ্যা করতে হয় তা নির্দেশ করে। বৈধ মানগুলি সারণি 1 এ বর্ণিত হয়েছে।
- পরিবর্তনশীল দৈর্ঘ্যের ধরন
- রেকর্ডের ধরন বর্ণনা করে।
TNF_WELL_KNOWN
ব্যবহার করলে, রেকর্ড টাইপ ডেফিনিশন (RTD) নির্দিষ্ট করতে এই ক্ষেত্রটি ব্যবহার করুন। বৈধ RTD মানগুলি সারণি 2 এ বর্ণিত হয়েছে। - পরিবর্তনশীল দৈর্ঘ্য আইডি
- রেকর্ডের জন্য একটি অনন্য শনাক্তকারী। এই ক্ষেত্রটি প্রায়শই ব্যবহার করা হয় না, তবে আপনার যদি একটি ট্যাগকে স্বতন্ত্রভাবে সনাক্ত করতে হয় তবে আপনি এটির জন্য একটি আইডি তৈরি করতে পারেন।
- পরিবর্তনশীল দৈর্ঘ্যের পেলোড
- প্রকৃত ডেটা পেলোড যা আপনি পড়তে বা লিখতে চান। একটি NDEF বার্তায় একাধিক NDEF রেকর্ড থাকতে পারে, তাই অনুমান করবেন না যে সম্পূর্ণ পেলোডটি NDEF বার্তার প্রথম NDEF রেকর্ডে রয়েছে৷
ট্যাগ ডিসপ্যাচ সিস্টেম এনডিইএফ বার্তায় একটি MIME প্রকার বা URI ম্যাপ করার চেষ্টা করার জন্য TNF এবং টাইপ ক্ষেত্র ব্যবহার করে। সফল হলে, এটি প্রকৃত পেলোড সহ একটি ACTION_NDEF_DISCOVERED
অভিপ্রায়ের ভিতরে সেই তথ্যগুলিকে অন্তর্ভুক্ত করে৷ যাইহোক, এমন কিছু ক্ষেত্রে আছে যখন ট্যাগ ডিসপ্যাচ সিস্টেম প্রথম NDEF রেকর্ডের উপর ভিত্তি করে ডেটার ধরন নির্ধারণ করতে পারে না। এটি ঘটে যখন NDEF ডেটা একটি MIME প্রকার বা URI-তে ম্যাপ করা যায় না, বা যখন NFC ট্যাগে শুরু করার জন্য NDEF ডেটা থাকে না। এই ধরনের ক্ষেত্রে, ট্যাগের প্রযুক্তি এবং পেলোড সম্পর্কে তথ্য আছে এমন একটি Tag
অবজেক্ট এর পরিবর্তে একটি ACTION_TECH_DISCOVERED
উদ্দেশ্যের ভিতরে এনক্যাপসুলেট করা হয়।
সারণী 1 বর্ণনা করে কিভাবে ট্যাগ ডিসপ্যাচ সিস্টেম TNF ম্যাপ করে এবং ক্ষেত্রগুলিকে MIME প্রকার বা URI-তে টাইপ করে। এটি বর্ণনা করে যে কোন TNFগুলিকে একটি MIME প্রকার বা URI-তে ম্যাপ করা যাবে না৷ এই ক্ষেত্রে, ট্যাগ ডিসপ্যাচ সিস্টেম ACTION_TECH_DISCOVERED
এ ফিরে আসে।
উদাহরণস্বরূপ, যদি ট্যাগ ডিসপ্যাচ সিস্টেমটি TNF_ABSOLUTE_URI
টাইপের একটি রেকর্ডের সম্মুখীন হয়, তাহলে এটি সেই রেকর্ডের পরিবর্তনশীল দৈর্ঘ্যের ক্ষেত্রটিকে একটি URI-তে ম্যাপ করে। ট্যাগ ডিসপ্যাচ সিস্টেম একটি ACTION_NDEF_DISCOVERED
উদ্দেশ্যের ডেটা ক্ষেত্রে সেই URIকে ট্যাগ সম্পর্কিত অন্যান্য তথ্যের সাথে অন্তর্ভুক্ত করে, যেমন পেলোড। অন্যদিকে, যদি এটি TNF_UNKNOWN
টাইপের একটি রেকর্ডের সম্মুখীন হয়, তবে এটি একটি উদ্দেশ্য তৈরি করে যা ট্যাগের প্রযুক্তিগুলিকে এনক্যাপসুলেট করে।
টাইপ নেম ফরম্যাট (TNF) | ম্যাপিং |
---|---|
TNF_ABSOLUTE_URI | টাইপ ক্ষেত্রের উপর ভিত্তি করে ইউআরআই। | TNF_EMPTY | ACTION_TECH_DISCOVERED এ ফিরে আসে। | TNF_EXTERNAL_TYPE | টাইপ ক্ষেত্রের ইউআরএন-এর উপর ভিত্তি করে ইউআরআই। URN একটি সংক্ষিপ্ত আকারে NDEF টাইপ ক্ষেত্রে এনকোড করা হয়েছে: <domain_name>:<service_name> । Android এটিকে একটি URI-তে এই ফর্মে ম্যাপ করে: vnd.android.nfc://ext/ <domain_name>:<service_name> । | TNF_MIME_MEDIA | টাইপ ক্ষেত্রের উপর ভিত্তি করে MIME প্রকার। | TNF_UNCHANGED | প্রথম রেকর্ডে অবৈধ, তাই ACTION_TECH_DISCOVERED এ ফিরে আসে। | TNF_UNKNOWN | ACTION_TECH_DISCOVERED এ ফিরে আসে। | TNF_WELL_KNOWN | MIME প্রকার বা URI রেকর্ড টাইপ ডেফিনিশন (RTD) এর উপর নির্ভর করে, যা আপনি টাইপ ক্ষেত্রে সেট করেছেন। উপলব্ধ RTD এবং তাদের ম্যাপিং সম্পর্কে আরও তথ্যের জন্য সারণী 2 দেখুন। |
রেকর্ড টাইপ ডেফিনিশন (RTD) | ম্যাপিং |
---|---|
RTD_ALTERNATIVE_CARRIER | ACTION_TECH_DISCOVERED এ ফিরে আসে। | RTD_HANDOVER_CARRIER | ACTION_TECH_DISCOVERED এ ফিরে আসে। | RTD_HANDOVER_REQUEST | ACTION_TECH_DISCOVERED এ ফিরে আসে। | RTD_HANDOVER_SELECT | ACTION_TECH_DISCOVERED এ ফিরে আসে। | RTD_SMART_POSTER | পেলোড পার্স করার উপর ভিত্তি করে ইউআরআই। | RTD_TEXT | MIME ধরনের text/plain । | RTD_URI | পেলোডের উপর ভিত্তি করে ইউআরআই। |
কীভাবে NFC ট্যাগগুলি অ্যাপ্লিকেশনগুলিতে পাঠানো হয়৷
যখন ট্যাগ ডিসপ্যাচ সিস্টেমটি একটি উদ্দেশ্য তৈরি করা হয় যা NFC ট্যাগ এবং এর সনাক্তকারী তথ্যকে এনক্যাপসুলেট করে, এটি একটি আগ্রহী অ্যাপ্লিকেশনের কাছে অভিপ্রায় পাঠায় যা অভিপ্রায়ের জন্য ফিল্টার করে। যদি একাধিক অ্যাপ্লিকেশন অভিপ্রায় পরিচালনা করতে পারে, তাহলে অ্যাক্টিভিটি চয়নকারী উপস্থাপন করা হয় যাতে ব্যবহারকারী কার্যকলাপ নির্বাচন করতে পারে। ট্যাগ ডিসপ্যাচ সিস্টেম তিনটি অভিপ্রায়কে সংজ্ঞায়িত করে, যা সর্বোচ্চ থেকে সর্বনিম্ন অগ্রাধিকারের ক্রম অনুসারে তালিকাভুক্ত করা হয়:
-
ACTION_NDEF_DISCOVERED
: এই উদ্দেশ্যটি একটি কার্যকলাপ শুরু করতে ব্যবহৃত হয় যখন একটি এনডিইএফ পেলোড ধারণকারী একটি ট্যাগ স্ক্যান করা হয় এবং এটি একটি স্বীকৃত প্রকার। এটি সর্বোচ্চ অগ্রাধিকারের অভিপ্রায়, এবং ট্যাগ প্রেরণ সিস্টেম যখনই সম্ভব অন্য কোনো অভিপ্রায়ের আগে এই অভিপ্রায়ের সাথে একটি কার্যকলাপ শুরু করার চেষ্টা করে। -
ACTION_TECH_DISCOVERED
:ACTION_NDEF_DISCOVERED
অভিপ্রায় পরিচালনা করার জন্য যদি কোনো কার্যক্রম নিবন্ধিত না হয়, ট্যাগ প্রেরণ সিস্টেম এই অভিপ্রায় দিয়ে একটি অ্যাপ্লিকেশন শুরু করার চেষ্টা করে। এই অভিপ্রায়টি সরাসরি শুরু হয় (প্রথমেACTION_NDEF_DISCOVERED
শুরু না করে) যদি স্ক্যান করা ট্যাগটিতে NDEF ডেটা থাকে যা একটি MIME প্রকার বা URI-তে ম্যাপ করা যায় না, অথবা যদি ট্যাগটিতে NDEF ডেটা না থাকে তবে এটি একটি পরিচিত ট্যাগ প্রযুক্তির। -
ACTION_TAG_DISCOVERED
: এই অভিপ্রায় শুরু হয় যদি কোনো ক্রিয়াকলাপACTION_NDEF_DISCOVERED
বাACTION_TECH_DISCOVERED
উদ্দেশ্যগুলি পরিচালনা না করে৷
ট্যাগ ডিসপ্যাচ সিস্টেম কাজ করার প্রাথমিক উপায় নিম্নরূপ:
- NFC ট্যাগ (হয়
ACTION_NDEF_DISCOVERED
বাACTION_TECH_DISCOVERED
) পার্স করার সময় ট্যাগ ডিসপ্যাচ সিস্টেম দ্বারা তৈরি করা অভিপ্রায়ে একটি কার্যকলাপ শুরু করার চেষ্টা করুন। - যদি কোনও অ্যাক্টিভিটি সেই অভিপ্রায়ের জন্য ফিল্টার না করে, তাহলে পরবর্তী সর্বনিম্ন অগ্রাধিকারের অভিপ্রায় (হয়
ACTION_TECH_DISCOVERED
বাACTION_TAG_DISCOVERED
) দিয়ে একটি অ্যাক্টিভিটি শুরু করার চেষ্টা করুন যতক্ষণ না কোনও অ্যাপ্লিকেশন অভিপ্রায়ের জন্য ফিল্টার না করে বা যতক্ষণ না ট্যাগ ডিসপ্যাচ সিস্টেম সমস্ত সম্ভাব্য উদ্দেশ্যগুলি চেষ্টা করে। - যদি কোনও উদ্দেশ্যগুলির জন্য কোনও অ্যাপ্লিকেশন ফিল্টার না করে তবে কিছুই করবেন না।
যখনই সম্ভব, NDEF বার্তা এবং ACTION_NDEF_DISCOVERED
উদ্দেশ্য নিয়ে কাজ করুন, কারণ এটি তিনটির মধ্যে সবচেয়ে নির্দিষ্ট। এই অভিপ্রায়টি আপনাকে ব্যবহারকারীকে আরও ভাল অভিজ্ঞতা প্রদান করে অন্য দুটি অভিপ্রায়ের চেয়ে আরও উপযুক্ত সময়ে আপনার অ্যাপ্লিকেশন শুরু করতে দেয়৷
Android ম্যানিফেস্টে NFC অ্যাক্সেসের অনুরোধ করুন
আপনি একটি ডিভাইসের NFC হার্ডওয়্যার অ্যাক্সেস করতে এবং সঠিকভাবে NFC ইন্টেন্টগুলি পরিচালনা করার আগে, আপনার AndroidManifest.xml
ফাইলে এই আইটেমগুলি ঘোষণা করুন:
- NFC হার্ডওয়্যার অ্যাক্সেস করার জন্য NFC
<uses-permission>
উপাদান:<uses-permission android:name="android.permission.NFC" />
- ন্যূনতম SDK সংস্করণ যা আপনার অ্যাপ্লিকেশন সমর্থন করতে পারে৷ API স্তর 9 শুধুমাত্র
ACTION_TAG_DISCOVERED
এর মাধ্যমে সীমিত ট্যাগ প্রেরণ সমর্থন করে, এবং শুধুমাত্রEXTRA_NDEF_MESSAGES
অতিরিক্ত মাধ্যমে NDEF বার্তাগুলিতে অ্যাক্সেস দেয়৷ অন্য কোন ট্যাগ বৈশিষ্ট্য বা I/O অপারেশন অ্যাক্সেসযোগ্য নয়। API স্তর 10-এ ব্যাপক পাঠক/লেখক সমর্থনের পাশাপাশি ফোরগ্রাউন্ড NDEF পুশিং অন্তর্ভুক্ত রয়েছে এবং API স্তর 14 NDEF রেকর্ড তৈরি করার জন্য অতিরিক্ত সুবিধার পদ্ধতি প্রদান করে।<uses-sdk android:minSdkVersion="10"/>
-
uses-feature
উপাদান যাতে আপনার অ্যাপ্লিকেশন শুধুমাত্র NFC হার্ডওয়্যার আছে এমন ডিভাইসগুলির জন্য Google Play-তে দেখানো হয়:<uses-feature android:name="android.hardware.nfc" android:required="true" />
যদি আপনার অ্যাপ্লিকেশনটি NFC কার্যকারিতা ব্যবহার করে, কিন্তু সেই কার্যকারিতাটি আপনার অ্যাপ্লিকেশনের জন্য গুরুত্বপূর্ণ নয়, আপনি
uses-feature
উপাদানটি বাদ দিতে পারেন এবংgetDefaultAdapter()
null
কিনা তা পরীক্ষা করে রানটাইমে NFC প্রাপ্যতা পরীক্ষা করতে পারেন।
NFC ইন্টেন্টের জন্য ফিল্টার
আপনার অ্যাপ্লিকেশান শুরু করতে যখন একটি NFC ট্যাগ যা আপনি পরিচালনা করতে চান তা স্ক্যান করা হয়, আপনার অ্যাপ্লিকেশনটি Android ম্যানিফেস্টে NFC অভিপ্রায়গুলির একটি, দুটি বা তিনটির জন্য ফিল্টার করতে পারে৷ যাইহোক, আপনার অ্যাপ্লিকেশন কখন শুরু হবে তার সর্বাধিক নিয়ন্ত্রণের জন্য আপনি সাধারণত ACTION_NDEF_DISCOVERED
অভিপ্রায়ের জন্য ফিল্টার করতে চান৷ ACTION_TECH_DISCOVERED
অভিপ্রায় হল ACTION_NDEF_DISCOVERED
এর জন্য একটি ফলব্যাক যখন ACTION_NDEF_DISCOVERED
এর জন্য কোনো অ্যাপ্লিকেশন ফিল্টার না থাকে বা যখন পেলোডটি NDEF না হয়। ACTION_TAG_DISCOVERED
এর জন্য ফিল্টারিং সাধারণত ফিল্টার করার জন্য একটি বিভাগের জন্য খুব সাধারণ। অনেক অ্যাপ্লিকেশান ACTION_TAG_DISCOVERED
এর আগে ACTION_NDEF_DISCOVERED
বা ACTION_TECH_DISCOVERED
এর জন্য ফিল্টার করবে, তাই আপনার অ্যাপ্লিকেশানের শুরু হওয়ার সম্ভাবনা কম। ACTION_TAG_DISCOVERED
শুধুমাত্র সেই ক্ষেত্রে ফিল্টার করার জন্য অ্যাপ্লিকেশনগুলির জন্য একটি শেষ অবলম্বন হিসাবে উপলব্ধ যেখানে ACTION_NDEF_DISCOVERED
বা ACTION_TECH_DISCOVERED
উদ্দেশ্য পরিচালনা করার জন্য অন্য কোনও অ্যাপ্লিকেশন ইনস্টল করা নেই৷
যেহেতু NFC ট্যাগ স্থাপনাগুলি পরিবর্তিত হয় এবং অনেক সময় আপনার নিয়ন্ত্রণে থাকে না, এটি সর্বদা সম্ভব হয় না, যার কারণে আপনি প্রয়োজনে অন্য দুটি অভিপ্রায়ে ফিরে যেতে পারেন৷ লিখিত ট্যাগ এবং ডেটার ধরনগুলির উপর আপনার নিয়ন্ত্রণ থাকলে, আপনার ট্যাগগুলি ফর্ম্যাট করতে NDEF ব্যবহার করার পরামর্শ দেওয়া হয়৷ নিম্নলিখিত বিভাগগুলি প্রতিটি ধরণের অভিপ্রায়ের জন্য কীভাবে ফিল্টার করতে হয় তা বর্ণনা করে৷
ACTION_NDEF_DISCOVERED
ACTION_NDEF_DISCOVERED
ইন্টেন্টের জন্য ফিল্টার করতে, আপনি যে ধরনের ডেটা ফিল্টার করতে চান তার সাথে ইন্টেন্ট ফিল্টার ঘোষণা করুন। নিম্নোক্ত উদাহরণ ACTION_NDEF_DISCOVERED
ইন্টেন্টের জন্য MIME ধরনের text/plain
সহ ফিল্টার:
<intent-filter> <action android:name="android.nfc.action.NDEF_DISCOVERED"/> <category android:name="android.intent.category.DEFAULT"/> <data android:mimeType="text/plain" /> </intent-filter>
নিম্নলিখিত উদাহরণগুলি https://developer.android.com/index.html
আকারে একটি URI-এর জন্য ফিল্টার করে।
<intent-filter> <action android:name="android.nfc.action.NDEF_DISCOVERED"/> <category android:name="android.intent.category.DEFAULT"/> <data android:scheme="https" android:host="developer.android.com" android:pathPrefix="/index.html" /> </intent-filter>
ACTION_TECH_DISCOVERED
যদি আপনার কার্যকলাপ ACTION_TECH_DISCOVERED
অভিপ্রায়ের জন্য ফিল্টার করে, তাহলে আপনাকে অবশ্যই একটি XML রিসোর্স ফাইল তৈরি করতে হবে যা tech-list
সেটের মধ্যে আপনার কার্যকলাপ সমর্থন করে এমন প্রযুক্তিগুলিকে নির্দিষ্ট করে৷ আপনার ক্রিয়াকলাপটিকে একটি মিল হিসাবে বিবেচনা করা হয় যদি একটি tech-list
সেটটি ট্যাগ দ্বারা সমর্থিত প্রযুক্তিগুলির একটি উপসেট হয়, যা আপনি getTechList()
কল করে পেতে পারেন।
উদাহরণস্বরূপ, যদি স্ক্যান করা ট্যাগটি MifareClassic, NdefFormatable এবং NfcA সমর্থন করে, তাহলে আপনার ক্রিয়াকলাপ মিলে যাওয়ার জন্য আপনার tech-list
সেটটি অবশ্যই তিনটি, দুটি বা একটি প্রযুক্তি (এবং অন্য কিছু নয়) উল্লেখ করতে হবে।
নিম্নলিখিত নমুনা সমস্ত প্রযুক্তি সংজ্ঞায়িত করে। আপনার NFC ট্যাগ দ্বারা সমর্থিত নয় এমনগুলি আপনাকে অবশ্যই সরিয়ে ফেলতে হবে৷ <project-root>/res/xml
ফোল্ডারে এই ফাইলটি সংরক্ষণ করুন (আপনি এটির নাম দিতে পারেন)।
<resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2"> <tech-list> <tech>android.nfc.tech.IsoDep</tech> <tech>android.nfc.tech.NfcA</tech> <tech>android.nfc.tech.NfcB</tech> <tech>android.nfc.tech.NfcF</tech> <tech>android.nfc.tech.NfcV</tech> <tech>android.nfc.tech.Ndef</tech> <tech>android.nfc.tech.NdefFormatable</tech> <tech>android.nfc.tech.MifareClassic</tech> <tech>android.nfc.tech.MifareUltralight</tech> </tech-list> </resources>
আপনি একাধিক tech-list
সেটও নির্দিষ্ট করতে পারেন। প্রতিটি tech-list
সেট স্বাধীনভাবে বিবেচনা করা হয়, এবং আপনার কার্যকলাপ একটি মিল হিসাবে বিবেচিত হয় যদি কোনো একক tech-list
সেটটি getTechList()
দ্বারা ফেরত দেওয়া প্রযুক্তিগুলির একটি উপসেট হয়। এটি মিলিত প্রযুক্তির জন্য AND
এবং OR
শব্দার্থবিদ্যা প্রদান করে। নিম্নলিখিত উদাহরণগুলি এমন ট্যাগগুলির সাথে মেলে যা NfcA এবং Ndef প্রযুক্তিগুলিকে সমর্থন করতে পারে বা NfcB এবং Ndef প্রযুক্তিগুলিকে সমর্থন করতে পারে:
<resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2"> <tech-list> <tech>android.nfc.tech.NfcA</tech> <tech>android.nfc.tech.Ndef</tech> </tech-list> <tech-list> <tech>android.nfc.tech.NfcB</tech> <tech>android.nfc.tech.Ndef</tech> </tech-list> </resources>
আপনার AndroidManifest.xml
ফাইলে, নিম্নলিখিত উদাহরণের মতো <activity>
উপাদানের ভিতরে <meta-data>
উপাদানে যে সংস্থান ফাইলটি তৈরি করেছেন তা নির্দিষ্ট করুন:
<activity> ... <intent-filter> <action android:name="android.nfc.action.TECH_DISCOVERED"/> </intent-filter> <meta-data android:name="android.nfc.action.TECH_DISCOVERED" android:resource="@xml/nfc_tech_filter" /> ... </activity>
ট্যাগ প্রযুক্তি এবং ACTION_TECH_DISCOVERED
উদ্দেশ্য নিয়ে কাজ করার বিষয়ে আরও তথ্যের জন্য, উন্নত NFC নথিতে সমর্থিত ট্যাগ প্রযুক্তিগুলির সাথে কাজ করা দেখুন৷
ACTION_TAG_আবিষ্কার
ACTION_TAG_DISCOVERED
ফিল্টার করতে নিম্নলিখিত উদ্দেশ্য ফিল্টারটি ব্যবহার করুন:
<intent-filter> <action android:name="android.nfc.action.TAG_DISCOVERED"/> </intent-filter>
উদ্দেশ্য থেকে তথ্য প্রাপ্ত
যদি একটি NFC অভিপ্রায়ের কারণে কোনো কার্যকলাপ শুরু হয়, তাহলে আপনি অভিপ্রায় থেকে স্ক্যান করা NFC ট্যাগ সম্পর্কে তথ্য পেতে পারেন। স্ক্যান করা ট্যাগের উপর নির্ভর করে ইন্টেন্টে নিম্নলিখিত অতিরিক্তগুলি থাকতে পারে:
-
EXTRA_TAG
(প্রয়োজনীয়): একটিTag
বস্তু যা স্ক্যান করা ট্যাগের প্রতিনিধিত্ব করে। -
EXTRA_NDEF_MESSAGES
(ঐচ্ছিক): ট্যাগ থেকে পার্স করা NDEF বার্তাগুলির একটি অ্যারে৷ এই অতিরিক্তACTION_NDEF_DISCOVERED
ইন্টেন্টে বাধ্যতামূলক৷ -
EXTRA_ID
(ঐচ্ছিক): ট্যাগের নিম্ন-স্তরের ID।
এই অতিরিক্তগুলি পেতে, একটি ট্যাগ স্ক্যান করা হয়েছে তা নিশ্চিত করতে আপনার কার্যকলাপটি NFC অভিপ্রায়গুলির একটি দিয়ে চালু করা হয়েছে কিনা তা পরীক্ষা করুন এবং তারপরে অভিপ্রায়ের বাইরে অতিরিক্তগুলি পান৷ নিম্নলিখিত উদাহরণটি ACTION_NDEF_DISCOVERED
অভিপ্রায়ের জন্য পরীক্ষা করে এবং একটি অতিরিক্ত অভিপ্রায় থেকে NDEF বার্তাগুলি পায়৷
কোটলিন
override fun onNewIntent(intent: Intent) { super.onNewIntent(intent) ... if (NfcAdapter.ACTION_NDEF_DISCOVERED == intent.action) { intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES)?.also { rawMessages -> val messages: List<NdefMessage> = rawMessages.map { it as NdefMessage } // Process the messages array. ... } } }
জাভা
@Override protected void onNewIntent(Intent intent) { super.onNewIntent(intent); ... if (NfcAdapter.ACTION_NDEF_DISCOVERED.equals(intent.getAction())) { Parcelable[] rawMessages = intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES); if (rawMessages != null) { NdefMessage[] messages = new NdefMessage[rawMessages.length]; for (int i = 0; i < rawMessages.length; i++) { messages[i] = (NdefMessage) rawMessages[i]; } // Process the messages array. ... } } }
বিকল্পভাবে, আপনি অভিপ্রায় থেকে একটি Tag
বস্তু পেতে পারেন, যাতে পেলোড থাকবে এবং আপনাকে ট্যাগের প্রযুক্তিগুলি গণনা করার অনুমতি দেবে:
কোটলিন
val tag: Tag = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG)
জাভা
Tag tag = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG);
সাধারণ ধরনের NDEF রেকর্ড তৈরি করুন
NFC ট্যাগে লেখার সময় আপনাকে সাহায্য করার জন্য কীভাবে সাধারণ ধরনের NDEF রেকর্ড তৈরি করা যায় এই বিভাগে বর্ণনা করে। Android 4.0 (API স্তর 14) দিয়ে শুরু করে, createUri()
পদ্ধতিটি স্বয়ংক্রিয়ভাবে URI রেকর্ড তৈরি করতে সাহায্য করার জন্য উপলব্ধ। Android 4.1 (API লেভেল 16) থেকে শুরু করে, createExternal()
এবং createMime()
আপনাকে MIME এবং বাহ্যিক ধরনের NDEF রেকর্ড তৈরি করতে সাহায্য করার জন্য উপলব্ধ। ম্যানুয়ালি NDEF রেকর্ড তৈরি করার সময় ভুলগুলি এড়াতে যখনই সম্ভব এই সাহায্যকারী পদ্ধতিগুলি ব্যবহার করুন৷
এই বিভাগটি বর্ণনা করে কিভাবে রেকর্ডের জন্য সংশ্লিষ্ট অভিপ্রায় ফিল্টার তৈরি করতে হয়। এই সমস্ত NDEF রেকর্ডের উদাহরণগুলি NDEF বার্তার প্রথম NDEF রেকর্ডে থাকা উচিত যা আপনি একটি ট্যাগে লিখছেন।
TNF_ABSOLUTE_URI
দ্রষ্টব্য: আমরা সুপারিশ করছি যে আপনি TNF_ABSOLUTE_URI
এর পরিবর্তে RTD_URI
টাইপ ব্যবহার করুন, কারণ এটি আরও কার্যকর।
আপনি নিম্নলিখিত উপায়ে একটি TNF_ABSOLUTE_URI
NDEF রেকর্ড তৈরি করতে পারেন:
কোটলিন
val uriRecord = ByteArray(0).let { emptyByteArray -> NdefRecord( TNF_ABSOLUTE_URI, "https://developer.android.com/index.html".toByteArray(Charset.forName("US-ASCII")), emptyByteArray, emptyByteArray ) }
জাভা
NdefRecord uriRecord = new NdefRecord( NdefRecord.TNF_ABSOLUTE_URI , "https://developer.android.com/index.html".getBytes(Charset.forName("US-ASCII")), new byte[0], new byte[0]);
পূর্ববর্তী NDEF রেকর্ডের জন্য অভিপ্রায় ফিল্টারটি দেখতে এইরকম হবে:
<intent-filter> <action android:name="android.nfc.action.NDEF_DISCOVERED" /> <category android:name="android.intent.category.DEFAULT" /> <data android:scheme="https" android:host="developer.android.com" android:pathPrefix="/index.html" /> </intent-filter>
TNF_MIME_MEDIA
আপনি নিম্নলিখিত উপায়ে একটি TNF_MIME_MEDIA
NDEF রেকর্ড তৈরি করতে পারেন:
createMime()
পদ্ধতি ব্যবহার করে:
কোটলিন
val mimeRecord = NdefRecord.createMime( "application/vnd.com.example.android.beam", "Beam me up, Android".toByteArray(Charset.forName("US-ASCII")) )
জাভা
NdefRecord mimeRecord = NdefRecord.createMime("application/vnd.com.example.android.beam", "Beam me up, Android".getBytes(Charset.forName("US-ASCII")));
ম্যানুয়ালি NdefRecord
তৈরি করা হচ্ছে:
কোটলিন
val mimeRecord = Charset.forName("US-ASCII").let { usAscii -> NdefRecord( NdefRecord.TNF_MIME_MEDIA, "application/vnd.com.example.android.beam".toByteArray(usAscii), ByteArray(0), "Beam me up, Android!".toByteArray(usAscii) ) }
জাভা
NdefRecord mimeRecord = new NdefRecord( NdefRecord.TNF_MIME_MEDIA , "application/vnd.com.example.android.beam".getBytes(Charset.forName("US-ASCII")), new byte[0], "Beam me up, Android!".getBytes(Charset.forName("US-ASCII")));
পূর্ববর্তী NDEF রেকর্ডের জন্য অভিপ্রায় ফিল্টারটি দেখতে এইরকম হবে:
<intent-filter> <action android:name="android.nfc.action.NDEF_DISCOVERED" /> <category android:name="android.intent.category.DEFAULT" /> <data android:mimeType="application/vnd.com.example.android.beam" /> </intent-filter>
RTD_TEXT এর সাথে TNF_WELL_KNOWN
আপনি নিম্নলিখিত উপায়ে একটি TNF_WELL_KNOWN
NDEF রেকর্ড তৈরি করতে পারেন:
কোটলিন
fun createTextRecord(payload: String, locale: Locale, encodeInUtf8: Boolean): NdefRecord { val langBytes = locale.language.toByteArray(Charset.forName("US-ASCII")) val utfEncoding = if (encodeInUtf8) Charset.forName("UTF-8") else Charset.forName("UTF-16") val textBytes = payload.toByteArray(utfEncoding) val utfBit: Int = if (encodeInUtf8) 0 else 1 shl 7 val status = (utfBit + langBytes.size).toChar() val data = ByteArray(1 + langBytes.size + textBytes.size) data[0] = status.toByte() System.arraycopy(langBytes, 0, data, 1, langBytes.size) System.arraycopy(textBytes, 0, data, 1 + langBytes.size, textBytes.size) return NdefRecord(NdefRecord.TNF_WELL_KNOWN, NdefRecord.RTD_TEXT, ByteArray(0), data) }
জাভা
public NdefRecord createTextRecord(String payload, Locale locale, boolean encodeInUtf8) { byte[] langBytes = locale.getLanguage().getBytes(Charset.forName("US-ASCII")); Charset utfEncoding = encodeInUtf8 ? Charset.forName("UTF-8") : Charset.forName("UTF-16"); byte[] textBytes = payload.getBytes(utfEncoding); int utfBit = encodeInUtf8 ? 0 : (1 << 7); char status = (char) (utfBit + langBytes.length); byte[] data = new byte[1 + langBytes.length + textBytes.length]; data[0] = (byte) status; System.arraycopy(langBytes, 0, data, 1, langBytes.length); System.arraycopy(textBytes, 0, data, 1 + langBytes.length, textBytes.length); NdefRecord record = new NdefRecord(NdefRecord.TNF_WELL_KNOWN, NdefRecord.RTD_TEXT, new byte[0], data); return record; }
পূর্ববর্তী NDEF রেকর্ডের জন্য অভিপ্রায় ফিল্টারটি দেখতে এইরকম হবে:
<intent-filter> <action android:name="android.nfc.action.NDEF_DISCOVERED" /> <category android:name="android.intent.category.DEFAULT" /> <data android:mimeType="text/plain" /> </intent-filter>
RTD_URI সহ TNF_WELL_KNOWN
আপনি নিম্নলিখিত উপায়ে একটি TNF_WELL_KNOWN
NDEF রেকর্ড তৈরি করতে পারেন:
createUri(String)
পদ্ধতি ব্যবহার করে:
কোটলিন
val rtdUriRecord1 = NdefRecord.createUri("https://example.com")
জাভা
NdefRecord rtdUriRecord1 = NdefRecord.createUri("https://example.com");
createUri(Uri)
পদ্ধতি ব্যবহার করে:
কোটলিন
val rtdUriRecord2 = Uri.parse("https://example.com").let { uri -> NdefRecord.createUri(uri) }
জাভা
Uri uri = Uri.parse("https://example.com"); NdefRecord rtdUriRecord2 = NdefRecord.createUri(uri);
ম্যানুয়ালি NdefRecord
তৈরি করা হচ্ছে:
কোটলিন
val uriField = "example.com".toByteArray(Charset.forName("US-ASCII")) val payload = ByteArray(uriField.size + 1) //add 1 for the URI Prefix payload [0] = 0x01 //prefixes https://www. to the URI System.arraycopy(uriField, 0, payload, 1, uriField.size) //appends URI to payload val rtdUriRecord = NdefRecord(NdefRecord.TNF_WELL_KNOWN, NdefRecord.RTD_URI, ByteArray(0), payload)
জাভা
byte[] uriField = "example.com".getBytes(Charset.forName("US-ASCII")); byte[] payload = new byte[uriField.length + 1]; //add 1 for the URI Prefix payload[0] = 0x01; //prefixes https://www. to the URI System.arraycopy(uriField, 0, payload, 1, uriField.length); //appends URI to payload NdefRecord rtdUriRecord = new NdefRecord( NdefRecord.TNF_WELL_KNOWN, NdefRecord.RTD_URI, new byte[0], payload);
পূর্ববর্তী NDEF রেকর্ডের জন্য অভিপ্রায় ফিল্টারটি দেখতে এইরকম হবে:
<intent-filter> <action android:name="android.nfc.action.NDEF_DISCOVERED" /> <category android:name="android.intent.category.DEFAULT" /> <data android:scheme="https" android:host="example.com" android:pathPrefix="" /> </intent-filter>
TNF_EXTERNAL_TYPE
আপনি নিম্নলিখিত উপায়ে একটি TNF_EXTERNAL_TYPE
NDEF রেকর্ড তৈরি করতে পারেন:
createExternal()
পদ্ধতি ব্যবহার করে:
কোটলিন
var payload: ByteArray //assign to your data val domain = "com.example" //usually your app's package name val type = "externalType" val extRecord = NdefRecord.createExternal(domain, type, payload)
জাভা
byte[] payload; //assign to your data String domain = "com.example"; //usually your app's package name String type = "externalType"; NdefRecord extRecord = NdefRecord.createExternal(domain, type, payload);
ম্যানুয়ালি NdefRecord
তৈরি করা হচ্ছে:
কোটলিন
var payload: ByteArray ... val extRecord = NdefRecord( NdefRecord.TNF_EXTERNAL_TYPE, "com.example:externalType".toByteArray(Charset.forName("US-ASCII")), ByteArray(0), payload )
জাভা
byte[] payload; ... NdefRecord extRecord = new NdefRecord( NdefRecord.TNF_EXTERNAL_TYPE, "com.example:externalType".getBytes(Charset.forName("US-ASCII")), new byte[0], payload);
পূর্ববর্তী NDEF রেকর্ডের জন্য অভিপ্রায় ফিল্টারটি দেখতে এইরকম হবে:
<intent-filter> <action android:name="android.nfc.action.NDEF_DISCOVERED" /> <category android:name="android.intent.category.DEFAULT" /> <data android:scheme="vnd.android.nfc" android:host="ext" android:pathPrefix="/com.example:externalType"/> </intent-filter>
অ্যান্ড্রয়েড-চালিত এবং নন-অ্যান্ড্রয়েড-চালিত ডিভাইসগুলিকে আরও ভালভাবে সমর্থন করতে আরও জেনেরিক NFC ট্যাগ স্থাপনের জন্য TNF_EXTERNAL_TYPE
ব্যবহার করুন৷
দ্রষ্টব্য : TNF_EXTERNAL_TYPE
এর জন্য URN-এর একটি ক্যানোনিকাল ফর্ম্যাট রয়েছে: urn:nfc:ext:example.com:externalType
, তবে NFC ফোরাম RTD স্পেসিফিকেশন ঘোষণা করে যে URN-এর urn:nfc:ext:
অংশটি অবশ্যই NDE রেকর্ড থেকে বাদ দিতে হবে। তাই আপনাকে যা দিতে হবে তা হল ডোমেইন (উদাহরণে example.com
) এবং টাইপ (উদাহরণে externalType
) একটি কোলন দ্বারা পৃথক করা। TNF_EXTERNAL_TYPE
পাঠানোর সময়, Android urn:nfc:ext:example.com:externalType
URN-কে একটি vnd.android.nfc://ext/example.com:externalType
URI-তে রূপান্তর করে, যা উদাহরণের উদ্দেশ্য ফিল্টার ঘোষণা করে।
অ্যান্ড্রয়েড অ্যাপ্লিকেশন রেকর্ড
Android 4.0 (API স্তর 14) এ প্রবর্তিত, একটি Android অ্যাপ্লিকেশন রেকর্ড (AAR) একটি শক্তিশালী নিশ্চিততা প্রদান করে যে যখন একটি NFC ট্যাগ স্ক্যান করা হয় তখন আপনার অ্যাপ্লিকেশন শুরু হয়। একটি AAR-এ একটি NDEF রেকর্ডের ভিতরে এমবেড করা একটি অ্যাপ্লিকেশনের প্যাকেজ নাম রয়েছে। আপনি আপনার NDEF বার্তার যেকোনো NDEF রেকর্ডে একটি AAR যোগ করতে পারেন, কারণ Android AAR-এর জন্য সম্পূর্ণ NDEF বার্তা অনুসন্ধান করে। যদি এটি একটি AAR খুঁজে পায় তবে এটি AAR-এর ভিতরে থাকা প্যাকেজের নামের উপর ভিত্তি করে অ্যাপ্লিকেশন শুরু করে। অ্যাপ্লিকেশনটি ডিভাইসে উপস্থিত না থাকলে, অ্যাপ্লিকেশনটি ডাউনলোড করার জন্য Google Play চালু করা হয়।
আপনি যদি একই অভিপ্রায়ের জন্য অন্যান্য অ্যাপ্লিকেশনগুলিকে ফিল্টার করা থেকে বিরত রাখতে চান এবং সম্ভাব্য নির্দিষ্ট ট্যাগগুলি পরিচালনা করতে চান যা আপনি মোতায়েন করেছেন তাহলে AARগুলি দরকারী৷ প্যাকেজ নামের সীমাবদ্ধতার কারণে AAR শুধুমাত্র অ্যাপ্লিকেশন স্তরে সমর্থিত, এবং উদ্দেশ্য ফিল্টারিংয়ের মতো কার্যকলাপ স্তরে নয়। আপনি যদি কার্যকলাপ স্তরে একটি অভিপ্রায় পরিচালনা করতে চান তবে অভিপ্রায় ফিল্টারগুলি ব্যবহার করুন ৷
যদি একটি ট্যাগে একটি AAR থাকে, তাহলে ট্যাগ প্রেরণ সিস্টেম নিম্নলিখিত পদ্ধতিতে প্রেরণ করে:
- স্বাভাবিক হিসাবে একটি অভিপ্রায় ফিল্টার ব্যবহার করে একটি কার্যকলাপ শুরু করার চেষ্টা করুন। অভিপ্রায়ের সাথে মেলে এমন কার্যকলাপ যদি AAR-এর সাথে মেলে, তাহলে কার্যকলাপ শুরু করুন।
- অভিপ্রায়ের জন্য ফিল্টার করা অ্যাক্টিভিটি যদি AAR-এর সাথে মেলে না, যদি একাধিক অ্যাক্টিভিটি অভিপ্রায় পরিচালনা করতে পারে, অথবা যদি কোনো অ্যাক্টিভিটি অভিপ্রায় পরিচালনা না করে, তাহলে AAR দ্বারা নির্দিষ্ট করা অ্যাপ্লিকেশনটি শুরু করুন৷
- যদি AAR দিয়ে কোনো অ্যাপ্লিকেশন শুরু না হয়, তাহলে AAR-এর উপর ভিত্তি করে অ্যাপ্লিকেশনটি ডাউনলোড করতে Google Play-তে যান।
দ্রষ্টব্য: আপনি ফোরগ্রাউন্ড ডিসপ্যাচ সিস্টেমের সাথে AAR এবং উদ্দেশ্য প্রেরণ সিস্টেমকে ওভাররাইড করতে পারেন, যা একটি NFC ট্যাগ আবিষ্কৃত হলে অগ্রভাগের কার্যকলাপকে অগ্রাধিকার দেওয়ার অনুমতি দেয়৷ এই পদ্ধতির সাহায্যে, AAR এবং অভিপ্রায় প্রেরণ ব্যবস্থাকে ওভাররাইড করার জন্য অ্যাক্টিভিটি অবশ্যই অগ্রভাগে থাকতে হবে।
আপনি যদি এখনও স্ক্যান করা ট্যাগগুলির জন্য ফিল্টার করতে চান যেগুলিতে AAR নেই, আপনি অভিপ্রায় ফিল্টারগুলিকে স্বাভাবিক হিসাবে ঘোষণা করতে পারেন। এটি উপযোগী যদি আপনার অ্যাপ্লিকেশনটি অন্য ট্যাগগুলিতে আগ্রহী হয় যাতে AAR নেই৷ উদাহরণস্বরূপ, হয়ত আপনি গ্যারান্টি দিতে চান যে আপনার অ্যাপ্লিকেশনটি মালিকানা ট্যাগগুলি পরিচালনা করে যা আপনি স্থাপন করেন সেইসাথে তৃতীয় পক্ষের দ্বারা মোতায়েন করা সাধারণ ট্যাগগুলি। মনে রাখবেন যে AARগুলি Android 4.0 বা তার পরবর্তী ডিভাইসগুলির জন্য নির্দিষ্ট, তাই ট্যাগগুলি স্থাপন করার সময়, আপনি সম্ভবত ডিভাইসগুলির বিস্তৃত পরিসরকে সমর্থন করার জন্য AAR এবং MIME প্রকার/URI-এর সংমিশ্রণ ব্যবহার করতে চান৷ উপরন্তু, আপনি যখন NFC ট্যাগগুলি স্থাপন করেন, তখন চিন্তা করুন যে আপনি কীভাবে আপনার NFC ট্যাগ লিখতে চান যাতে অধিকাংশ ডিভাইসের (Android-চালিত এবং অন্যান্য ডিভাইস) জন্য সমর্থন সক্ষম করা যায়। আপনি একটি অপেক্ষাকৃত অনন্য MIME প্রকার বা URI সংজ্ঞায়িত করে এটি করতে পারেন যাতে অ্যাপ্লিকেশনগুলিকে আলাদা করা সহজ হয়৷
অ্যান্ড্রয়েড একটি AAR তৈরি করতে একটি সাধারণ API প্রদান করে, createApplicationRecord()
। আপনাকে যা করতে হবে তা হল আপনার NdefMessage
যেকোনো জায়গায় AAR এম্বেড করা। আপনি আপনার NdefMessage
এর প্রথম রেকর্ডটি ব্যবহার করতে চান না, যদি না NdefMessage
এ AAR একমাত্র রেকর্ড না হয়। এর কারণ হল অ্যান্ড্রয়েড সিস্টেম ট্যাগের MIME প্রকার বা URI নির্ধারণ করতে একটি NdefMessage
এর প্রথম রেকর্ড পরীক্ষা করে, যা অ্যাপ্লিকেশনগুলিকে ফিল্টার করার জন্য একটি উদ্দেশ্য তৈরি করতে ব্যবহৃত হয়। নিম্নলিখিত কোড আপনাকে দেখায় কিভাবে একটি AAR তৈরি করতে হয়:
কোটলিন
val msg = NdefMessage( arrayOf( ..., NdefRecord.createApplicationRecord("com.example.android.beam") ) )
জাভা
NdefMessage msg = new NdefMessage( new NdefRecord[] { ..., NdefRecord.createApplicationRecord("com.example.android.beam")} ); )