একটি ওয়েবক্যাম হিসাবে একটি ডিভাইস ব্যবহার করুন

Android 14-QPR1 বা উচ্চতর সংস্করণে চলমান ডিভাইসগুলির জন্য, Android একটি USB ওয়েবক্যাম হিসাবে ডিভাইস ব্যবহার করা সমর্থন করে। এই বৈশিষ্ট্যটিকে সমর্থন করে এমন অ্যান্ড্রয়েড ডিভাইসগুলিকে একটি UVC ডিভাইস হিসাবে বিজ্ঞাপন দেওয়া হয়, যা বিভিন্ন অপারেটিং সিস্টেমের (উদাহরণস্বরূপ, Linux, macOS, Windows, এবং ChromeOS) সাথে একটি বিস্তৃত USB হোস্টকে ডিভাইসের ক্যামেরাকে ওয়েবক্যাম হিসাবে ব্যবহার করতে দেয়৷ DeviceAsWebcam পরিষেবাটি একটি ওয়েবক্যাম হিসাবে ডিভাইসটি ব্যবহার করতে এই বৈশিষ্ট্যটিকে সমর্থন করে৷

DeviceAsWebcam পরিষেবা

AOSP-এর DeviceAsWebcam পরিষেবাটিতে একটি প্রিভিউ অ্যাক্টিভিটি ( DeviceAsWebcamPreview.java ) রয়েছে যা ব্যবহারকারীদের দৃশ্য ফ্রেম করতে দেয়। পূর্বরূপ কার্যকলাপ ব্যবহারকারীকে নিম্নলিখিত করতে দেয়:

  • স্ট্রিমিং শুরু হওয়ার আগে হোস্ট মেশিনে ওয়েবক্যাম ফিড কেমন দেখাবে তা পূর্বরূপ দেখুন।

  • নিম্নলিখিত উপায়ে হোস্টে পাঠানো ওয়েবক্যাম ফিড কাস্টমাইজ করুন:

    • সামনে বা পিছনে স্ট্রিম করার জন্য ক্যামেরা নির্বাচন করা হচ্ছে।
    • একটি স্লাইডার বা বোতাম ব্যবহার করে জুম স্তর নির্বাচন করা।
    • একটি অঞ্চলে ফোকাস ফোকাস বা সরাতে পূর্বরূপের একটি নির্দিষ্ট অঞ্চলে আলতো চাপুন৷

পূর্বরূপ ক্রিয়াকলাপটি Android এ সাধারণ অ্যাক্সেসিবিলিটি বৈশিষ্ট্যগুলির সাথে কাজ করে যেমন টকব্যাক , সুইচ অ্যাক্সেস এবং ভয়েস অ্যাক্সেস

ওয়েবক্যাম ফিড হোস্টে স্ট্রিম করা হয়েছে

চিত্র 1. ওয়েবক্যাম ফিড একটি হোস্টে স্ট্রিম করা হচ্ছে এবং ফিড নিয়ন্ত্রণের পূর্বরূপ।

স্থাপত্য

একটি ওয়েবক্যাম হিসাবে একটি ডিভাইস ব্যবহার করে সমর্থন করার আর্কিটেকচারটি চিত্র 2-এ চিত্রিত করা হয়েছে৷ নিম্নলিখিতটি Android ফ্রেমওয়ার্কের বাকি অংশের সাথে DeviceAsWebcam পরিষেবার মিথস্ক্রিয়া প্রবাহকে বর্ণনা করে:

  1. ব্যবহারকারী সেটিংস অ্যাপে USB ওয়েবক্যাম বিকল্পটি নির্বাচন করেন।
  2. সেটিংস অ্যাপটি UsbManager ক্লাসের মাধ্যমে system_server একটি বাইন্ডার কল পাঠায় এবং এটি জানায় যে FUNCTION_UVC নির্বাচন করা হয়েছে।
  3. সিস্টেম সার্ভার নিম্নলিখিত কাজ করে:
    1. একটি setUsbFunctions HAL ইন্টারফেস কলের মাধ্যমে UVC গ্যাজেট ফাংশন পুনরুদ্ধার করতে USB গ্যাজেট HAL-কে জানায়৷
    2. ConfigFs ব্যবহার করে UVC গ্যাজেট ড্রাইভার কনফিগার করতে USB গ্যাজেট HAL-কে জানায়।
  4. গ্যাজেট HAL থেকে একটি কলব্যাক প্রাপ্তির পরে, system_server ফ্রেমওয়ার্কে একটি সম্প্রচার পাঠায় যা DeviceAsWebcam পরিষেবা দ্বারা নেওয়া হবে৷
  5. USB গ্যাজেট ড্রাইভার /dev/video* এ V4L2 নোডের মাধ্যমে হোস্টের কাছ থেকে কনফিগারেশন কমান্ড পাওয়ার পরে ওয়েবক্যাম স্ট্রীম শুরু করে।

ওয়েবক্যাম আর্কিটেকচার হিসাবে ডিভাইস

চিত্র 2. DeviceAsWebcam আর্কিটেকচার।

বাস্তবায়ন

এই বিভাগটি বর্ণনা করে যে কীভাবে একটি অ্যান্ড্রয়েড ডিভাইসকে ওয়েবক্যাম হিসেবে ব্যবহার করে সমর্থন করা যায়।

কার্নেল সমর্থন

Android 14 বা তার বেশির জন্য, জেনেরিক কার্নেল ইমেজ (GKI) ডিফল্টরূপে UVC গ্যাজেট ড্রাইভারকে সক্ষম করে ( AOSP প্যাচে বিস্তারিত দেখুন)।

গ্যাজেট HAL-এ UVC সমর্থন করুন

Android 14 দিয়ে শুরু করে, UVC ফাংশন GadgetFunction.aidl HAL ইন্টারফেসে অন্তর্ভুক্ত করা হয়েছে। গ্যাজেট HAL-এর জন্য, UVC গ্যাজেটটি ConfigFS-এ একইভাবে মাউন্ট করা হয় যেমন MTP বা ADB-এর মতো অন্যান্য ConfigFS ফাংশন।

গ্যাজেট HAL বাস্তবায়ন করতে, UVC ফাংশনটিকে ConfigFS-এ মাউন্ট করার জন্য পরিবর্তন করুন। নীচে UVC ফাংশন সমর্থন করে একটি গ্যাজেট HAL বাস্তবায়নের একটি উদাহরণ স্নিপেট:

UsbGadget::setCurrentUsbFunctions(long functions) {
   ...
   // Existing functions
   if ((functions & GadgetFunction::MTP) != 0) {
       ...
       linkFunction("ffs.mtp"); // Mount to ConfigFS
       ...
   }
   ...
   // UVC function follows the same pattern!
   if ((functions & GadgetFunction::UVC) != 0) {
       ...
       linkFunction("uvc.0"); // Mount to ConfigFS
       ...
   }
   ...
}

যখন ডিভাইসটি একটি ওয়েবক্যাম হিসাবে কাজ করে, তখন নিশ্চিত করুন যে USB গ্যাজেট HAL সঠিক VID/PID সমন্বয়ের বিজ্ঞাপন দিচ্ছে৷

যেহেতু সমস্ত UVC লজিক বিক্রেতা init বা DeviceAsWebcam পরিষেবাতে রয়েছে, তাই গ্যাজেট HAL-এ UVC ফাংশনকে ConfigFS-এ সিমলিংক করা ছাড়া অন্য কোনও UVC নির্দিষ্ট যুক্তির প্রয়োজন নেই৷

বাস্তবায়নের বিষয়ে আরও নির্দেশনার জন্য, AOSP-তে নিম্নলিখিত নমুনা কোডটি দেখুন:

UVC কনফিগারেশন সহ ConfigFS সেট আপ করুন

UVC গ্যাজেট ড্রাইভারকে জানাতে যে কোন ফর্ম্যাট, আকার এবং ফ্রেম রেটগুলি Android ওয়েবক্যাম দ্বারা সমর্থিত, UVC কনফিগারেশন সহ ConfigFS সেট আপ করুন৷ আরও তথ্যের জন্য, কনফিগএফএস ইউভিসি গ্যাজেট ABI- তে আপস্ট্রিম লিনাক্স ডকুমেন্টেশন দেখুন।

নিচের একটি উদাহরণ হল কিভাবে ভেন্ডর init UVC গ্যাজেট ড্রাইভার সেট আপ করতে পারে ( AOSP-এ কোড স্নিপেট ):

# uvc function
   mkdir /configfs_path/functions/uvc.0
   write /configfs_path/functions/uvc.0/function_name "Android Webcam"
   write /configfs_path/functions/uvc.0/streaming_maxpacket 3072
   # setup control params
   mkdir /configfs_path/functions/uvc.0/control/header/h
   symlink /configfs_path/functions/uvc.0/control/header/h \
                /configfs_path/functions/uvc.0/control/class/fs/h
   symlink /configfs_path/functions/uvc.0/control/header/h \
                /configfs_path/functions/uvc.0/control/class/ss/h
   # advertise 1080p resolution for webcam encoded as mjpeg
   mkdir /configfs_path/functions/uvc.0/streaming/mjpeg/m/1080p
   write /configfs_path/functions/uvc.0/streaming/mjpeg/m/1080p/wHeight 1080
   write /configfs_path/functions/uvc.0/streaming/mjpeg/m/1080p/wWidth 1920
   write /configfs_path/functions/uvc.0/streaming/mjpeg/m/1080p/dwMaxVideoFrameBufferSize 4147200
   # advertise 30 fps support for 1080p.
   write /configfs_path/functions/uvc.0/streaming/mjpeg/m/1080p/dwDefaultFrameInterval 333333
   write /configfs_path/functions/uvc.0/streaming/mjpeg/m/1080p/dwFrameInterval "333333"
   # setup streaming params
   mkdir /configfs_path/functions/uvc.0/streaming/header/h
   symlink /configfs_path/functions/uvc.0/streaming/mjpeg/m \
                /configfs_path/functions/uvc.0/streaming/header/h/m
   symlink /configfs_path/functions/uvc.0/streaming/header/h \
                /configfs_path/functions/uvc.0/streaming/class/fs/h
   symlink /configfs_path/functions/uvc.0/streaming/header/h \
                /configfs_path/functions/uvc.0/streaming/class/hs/h
   symlink /configfs_path/functions/uvc.0/streaming/header/h \
                /config/usb_gadget/g1/functions/uvc.0/streaming/class/ss/h
   # ...

এই স্নিপেটটি 30 fps এ একটি 1080p MJPEG স্ট্রীম বিজ্ঞাপন দেওয়ার জন্য UVC গ্যাজেট ড্রাইভার সেট আপ করে৷ এই ক্ষমতাগুলি USB হোস্টের সাথে যোগাযোগ করা হয় যখন এটি সমর্থিত রেজোলিউশন এবং ফ্রেম রেটগুলি জিজ্ঞাসা করে।

ওয়েবক্যাম যে কনফিগারেশনের বিজ্ঞাপন দেয় তা নির্বাচন করার জন্য নিম্নলিখিত সাধারণ নির্দেশিকা রয়েছে:

  • DeviceAsWebcam পরিষেবা দ্বারা সমর্থিত দুটি স্ট্রিম ফরম্যাট হল MJPEG এবং uncompressed YUYV।
  • USB 2.0 480 Mbps (60 MBps) ডেটা স্থানান্তর সমর্থন করে। এর মানে হল যে 30 fps এ, প্রতিটি ফ্রেমের সর্বোচ্চ আকার 2 MB থাকতে হবে; এবং 60 fps এ, সর্বোচ্চ 1 MB সাইজ।
    • আনকম্প্রেসড স্ট্রীম (YUYV): 30 fps এ, সর্বাধিক সমর্থিত ফ্রেমের আকার 720p কারণ YUYV প্রতি পিক্সেল 2 বাইট।
    • সংকুচিত MJPEG স্ট্রীম: YUV থেকে 1:10 কম্প্রেশন অনুপাত ধরে নিলে, USB 2.0 4K (প্রতি ফ্রেমে 1.18 MB) সমর্থন করতে পারে।
  • প্রাথমিক সামনের এবং পিছনের ক্যামেরা ডিভাইসগুলিকে বিজ্ঞাপন দেওয়া সমস্ত ফ্রেমের আকারগুলিকে সমর্থন করতে হবে৷ এর কারণ হল ব্যবহারকারী পূর্বরূপ UI ব্যবহার করে ক্যামেরা আইডিগুলির মধ্যে স্যুইচ করতে পারে৷ MJPEG স্ট্রীমগুলির জন্য, আমরা বিক্রেতাদের 480p (640 x 480), 720p (1280 x 820) এবং 1080p (1920 x 1080) ফ্রেম আকারের বিজ্ঞাপন দেওয়ার পরামর্শ দিই কারণ এইগুলি সাধারণত হোস্ট অ্যাপ দ্বারা ব্যবহৃত মাপ।
  • প্রাথমিক সামনের এবং পিছনের ক্যামেরা ডিভাইসগুলিকে অবশ্যই বিজ্ঞাপন দেওয়া সমস্ত ফ্রেম রেট সমর্থন করতে হবে৷ আমরা দৃঢ়ভাবে বিক্রেতাদের সুপারিশ 30 fps সমর্থন.

ওয়েবক্যাম স্ট্রিম কনফিগারেশন (ConfigFS) যোগ করার উদাহরণের জন্য, AOSP নমুনা প্যাচ দেখুন।

বিল্ডে ওয়েবক্যাম সক্রিয় করুন

DeviceAsWebcam পরিষেবা সক্ষম করার জন্য, আপনাকে অবশ্যই device.mk ফাইলে ro.usb.uvc.enabled সিস্টেম বৈশিষ্ট্য true হিসাবে সেট করতে হবে৷

# Enable UVC support
PRODUCT_VENDOR_PROPERTIES += \
    ro.usb.uvc.enabled=true

যখন এই সিস্টেম প্রপার্টি সক্রিয় করা হয়, তখন চিত্র 3-তে দেখানো হিসাবে USB পছন্দগুলির অধীনে সেটিংস অ্যাপে একটি ওয়েবক্যাম বিকল্প উপস্থিত হয়। বিকল্পটি নির্বাচন করা হলে, হোস্ট ডিভাইসে Android ডিভাইসটি একটি USB ওয়েবক্যাম হিসাবে উপস্থিত হয়।

চিত্র 3. সেটিংস অ্যাপে USB পছন্দগুলি৷

আপনি এই কমান্ডটি ব্যবহার করে ADB এর মাধ্যমে USB ওয়েবক্যাম ফাংশনে ডিভাইসটিকে সেট করতে পারেন:

adb shell svc usb setFunctions uvc

শক্তি এবং তাপ উদ্বেগ বিবেচনা করুন

ওয়েবক্যাম অপারেশনের অর্থ হল একটি ডিভাইসের ক্যামেরা দিনে একাধিক ঘন্টার জন্য চালু থাকতে পারে, তাই আমরা নিশ্চিত করার জন্য ব্যবস্থা নেওয়ার পরামর্শ দিই যে ডিভাইসের বিদ্যুৎ খরচ এবং তাপ নির্দিষ্ট সীমার মধ্যে থাকে। বিদ্যুতের ব্যবহার সীমার মধ্যে রাখার জন্য নিম্নলিখিতগুলি সুপারিশ করা হয়েছে:

  • ক্যামেরা HAL থেকে আরও ভাল পাওয়ার পারফরম্যান্সের জন্য, DeviceAsWebcam পরিষেবাতে STREAM_USE_CASE_VIDEO_CALL সক্ষম করুন৷
  • STREAM_USE_CASE_VIDEO_CALL সক্ষম থাকা সত্ত্বেও যদি পাওয়ার একটি উদ্বেগের বিষয় হয়, তাহলে DeviceAsWebcam পরিষেবাটি শারীরিক স্ট্রিমগুলি ব্যবহার করে আরও শক্তি খরচ কমানোর বিকল্প প্রদান করে৷ কোন ফিজিক্যাল ক্যামেরা ব্যবহার করতে হবে তা নির্দিষ্ট করতে আপনি রানটাইম রিসোর্স ওভারলে (RROs) ব্যবহার করতে পারেন। শারীরিক স্ট্রীমগুলি ভিডিওর গুণমানকে উল্লেখযোগ্যভাবে হ্রাস করে এবং একটি বিভ্রান্তিকর UX নিয়ে যায়, তাই এই সমাধানটি শুধুমাত্র শেষ অবলম্বন হিসাবে ব্যবহার করুন৷ STREAM_USE_CASE_VIDEO_CALL অপ্টিমাইজ করা হল পাওয়ার উদ্বেগের জন্য পছন্দের সমাধান৷ DeviceAsWebcam পরিষেবা দ্বারা সমর্থিত RRO সম্পর্কে আরও তথ্যের জন্য, readme.md দেখুন।

    নিচে লজিক্যাল ক্যামেরা আইডি 0 এর পরিবর্তে ফিজিক্যাল ক্যামেরা আইডি 3 ব্যবহার করার জন্য একটি RRO সেট আপ করা হয়েছে। AOSP-এ উদাহরণের জন্য DeviceAsWebcamRaven দেখুন।

    // For logical camera id 0 - use physical camera id 3
    {"0": {"3" : "UW"}}
    

যাচাইকরণ

আপনার ডিভাইসে DeviceAsWebcam পরিষেবার প্রয়োগ পরীক্ষা করতে, নিম্নলিখিত পরীক্ষাগুলি ব্যবহার করুন:

  • CTS ভেরিফায়ার টেস্ট ওয়েবক্যাম : পরীক্ষা করুন যে ফর্ম্যাট, আকার এবং ফ্রেম রেট ডিভাইস দ্বারা সমর্থিত।
  • ম্যানুয়াল পরীক্ষা: ওয়েবক্যাম বৈশিষ্ট্যটি বিভিন্ন হোস্ট অপারেটিং সিস্টেমে বিভিন্ন হোস্ট অ্যাপের সাথে কাজ করে কিনা তা পরীক্ষা করুন।

পরিচিত সমস্যা

DeviceAsWebcam পরিষেবার জন্য নিম্নলিখিতগুলি পরিচিত সমস্যাগুলি: