आप इसका इस्तेमाल करके मैसेज भेजते हैं
MessageClient
एपीआई को खोलें और ये आइटम मैसेज में अटैच करें:
- वैकल्पिक स्वैच्छिक पेलोड
- ऐसा पाथ जो मैसेज की कार्रवाई की खास तौर पर पहचान करता है
डेटा आइटम के मामले में अलग, इन आइटम के बीच कोई सिंक नहीं होता हैंडहेल्ड और पहने जाने वाले ऐप्लिकेशन. मैसेज, रिमोट प्रोसेस कॉल (आरपीसी) के लिए इस्तेमाल होने वाला एकतरफ़ा कम्यूनिकेशन सिस्टम है, जैसे, कोई गतिविधि शुरू करने के लिए, पहने जाने वाले डिवाइस पर मैसेज भेजना.
पहने जाने वाले कई डिवाइसों को उपयोगकर्ता के हैंडहेल्ड डिवाइस से कनेक्ट किया जा सकता है. कनेक्ट किए गए हर डिवाइस को नेटवर्क को नोड माना जाता है.
कनेक्ट किए गए कई डिवाइसों के साथ, आपको इस बात का ध्यान रखना होगा कि नोड को मैसेज मिलते हैं. उदाहरण के लिए, वॉइस ट्रांसक्रिप्शन ऐप्लिकेशन में, जिस पर आवाज़ का डेटा आता है पहने जाने योग्य डिवाइस, तो प्रोसेसिंग पावर और बैटरी वाले नोड को संदेश भेजें अनुरोध को हैंडल करने की क्षमता, जैसे कि हैंडहेल्ड डिवाइस.
ध्यान दें: अपने मैसेज की जानकारी देते समय, एक से ज़्यादा मैसेज की संभावना को ध्यान में रखें कनेक्ट किए गए नोड. पक्का करें कि मैसेज, तय किए गए डिवाइसों या नोड पर डिलीवर किया गया हो.
इस्तेमाल के उदाहरणों के लिए, नीचे दिए गए ऐप्लिकेशन का नमूना देखें: Dataलेयर
मैसेज भेजें
पहने जाने वाले ऐप्लिकेशन, उपयोगकर्ताओं को कई सुविधाएं दे सकते हैं. जैसे, आवाज़ से जुड़ी कोई सुविधा बोले जा रहे शब्दों को टेक्स्ट में बदला जा सकता है. उपयोगकर्ता, पहने जाने वाले अपने डिवाइस के माइक्रोफ़ोन में बोल सकते हैं और ट्रांसक्रिप्ट पा सकते हैं नोट में सेव हो जाते हैं. पहने जाने वाले डिवाइस में, आम तौर पर प्रोसेसिंग पावर और बैटरी नहीं होती है बोली को लेख में बदलने की गतिविधि को हैंडल करने की ज़रूरत होती है, इसलिए ऐप को यह काम बेहतर तरीके से कनेक्ट करने में मदद करता है.
नीचे दिए गए सेक्शन में, गतिविधि को प्रोसेस करने वाले डिवाइस नोड का विज्ञापन करने का तरीका बताया गया है का अनुरोध किया जा सकता है, अनुरोध की गई ज़रूरत को पूरा करने वाले नोड खोजे जा सकते हैं, और उन लोगों को मैसेज भेजे जा सकते हैं नोड.
विज्ञापन दिखाने की सुविधाएं
पहने जाने वाले डिवाइस से, हैंडहेल्ड डिवाइस पर कोई गतिविधि लॉन्च करने के लिए,
अनुरोध भेजने के लिए,
MessageClient
क्लास. कई पहने जाने वाले डिवाइसों से
Google Analytics 4 प्रॉपर्टी से कनेक्ट किया जा सकता है
हैंडहेल्ड डिवाइस होता है, तो पहने जाने वाले ऐप्लिकेशन को यह पता लगाने की ज़रूरत होती है कि कनेक्ट किया गया नोड
वह गतिविधि लॉन्च करने में सक्षम हो. अपने हैंडहेल्ड ऐप्लिकेशन में, विज्ञापन दें कि नोड
यह टेक्नोलॉजी कुछ ख़ास सुविधाएँ उपलब्ध कराती है.
हैंडहेल्ड ऐप्लिकेशन की सुविधाओं का विज्ञापन देने के लिए, ये काम करें:
- अपने प्रोजेक्ट की
res/values/
डायरेक्ट्री में एक एक्सएमएल कॉन्फ़िगरेशन फ़ाइल बनाएं और इसेwear.xml
नाम दें. wear.xml
मेंandroid_wear_capabilities
नाम का संसाधन जोड़ें.- डिवाइस से मिलने वाली क्षमताओं को तय करें.
ध्यान दें: सुविधाएं, कस्टम स्ट्रिंग होती हैं जिन्हें आपने तय किया होता है. ये आपके ऐप्लिकेशन के लिए यूनीक होनी चाहिए.
नीचे दिए गए उदाहरण में, voice_transcription
नाम की सुविधा को जोड़ने का तरीका बताया गया है
wear.xml
:
<resources xmlns:tools="http://schemas.android.com/tools" tools:keep="@array/android_wear_capabilities"> <string-array name="android_wear_capabilities"> <item>voice_transcription</item> </string-array> </resources>
ज़रूरी क्षमताओं वाले नोड वापस पाना
शुरुआत में, आप
getCapability
तरीका
CapabilityClient
क्लास. इस तरीके का इस्तेमाल करने के लिए, आपका Wear OS ऐप्लिकेशन और फ़ोन ऐप्लिकेशन
ऐप्लिकेशन आईडी एक ही होना चाहिए. यह उदाहरण
यह दिखाता है कि
voice_transcription
क्षमता:
Kotlin
private const val VOICE_TRANSCRIPTION_CAPABILITY_NAME = "voice_transcription" ... private fun setupVoiceTranscription() { val capabilityInfo: CapabilityInfo = Tasks.await( Wearable.getCapabilityClient(context) .getCapability( VOICE_TRANSCRIPTION_CAPABILITY_NAME, CapabilityClient.FILTER_REACHABLE ) ) // capabilityInfo has the reachable nodes with the transcription capability updateTranscriptionCapability(capabilityInfo) }
Java
private static final String VOICE_TRANSCRIPTION_CAPABILITY_NAME = "voice_transcription"; ... private void setupVoiceTranscription() { CapabilityInfo capabilityInfo = Tasks.await( Wearable.getCapabilityClient(context).getCapability( VOICE_TRANSCRIPTION_CAPABILITY_NAME, CapabilityClient.FILTER_REACHABLE)); // capabilityInfo has the reachable nodes with the transcription capability updateTranscriptionCapability(capabilityInfo); }
पहने जाने वाले डिवाइस से कनेक्ट होने पर सक्षम नोड का पता लगाने के लिए,
लिसनर का इंस्टेंस, खास तौर पर OnCapabilityChangedListener
एक CapabilityClient
ऑब्जेक्ट में. नीचे दिए गए उदाहरण में,
लिसनर को रजिस्टर करें और रीचेबल नोड के साथ नतीजा पाएं
voice_transcription
क्षमता:
Kotlin
private fun setupVoiceTranscription() { updateTranscriptionCapability(capabilityInfo).also { capabilityListener -> Wearable.getCapabilityClient(context).addListener( capabilityListener, VOICE_TRANSCRIPTION_CAPABILITY_NAME ) } }
Java
private void setupVoiceTranscription() { ... // This example uses a Java 8 Lambda. You can use named or anonymous classes. CapabilityClient.OnCapabilityChangedListener capabilityListener = capabilityInfo -> { updateTranscriptionCapability(capabilityInfo); }; Wearable.getCapabilityClient(context).addListener( capabilityListener, VOICE_TRANSCRIPTION_CAPABILITY_NAME); }
सक्षम नोड का पता लगाने के बाद, यह तय करें कि मैसेज कहां भेजना है. कोई नोड चुनें
जो पहने जाने वाले डिवाइस के नज़दीक हो.
मैसेज रूटिंग कई नोड से होकर गुज़रता है. आस-पास के नोड को सीधे तौर पर कनेक्ट किया गया नोड माना जाता है
डिवाइस से कनेक्ट करते हैं. यह पता लगाने के लिए कि कोई नोड आस-पास है, जैसे कि ब्लूटूथ के ज़रिए कनेक्ट किया गया है,
Node.isNearby()
तरीका. अगर आस-पास एक से ज़्यादा नोड हैं, तो मनचाहे तरीके से एक को चुनें;
इसी तरह, अगर आस-पास कोई सक्षम नोड मौजूद नहीं है, तो मनचाहे तरीके से सक्षम नोड चुनें.
नीचे दिया गया उदाहरण दिखाता है कि आप इस्तेमाल के लिए सबसे अच्छे नोड को कैसे तय कर सकते हैं:
Kotlin
private var transcriptionNodeId: String? = null private fun updateTranscriptionCapability(capabilityInfo: CapabilityInfo) { transcriptionNodeId = pickBestNodeId(capabilityInfo.nodes) } private fun pickBestNodeId(nodes: Set<Node>): String? { // Find a nearby node or pick one arbitrarily. return nodes.firstOrNull { it.isNearby }?.id ?: nodes.firstOrNull()?.id }
Java
private String transcriptionNodeId = null; private void updateTranscriptionCapability(CapabilityInfo capabilityInfo) { Set<Node> connectedNodes = capabilityInfo.getNodes(); transcriptionNodeId = pickBestNodeId(connectedNodes); } private String pickBestNodeId(Set<Node> nodes) { String bestNodeId = null; // Find a nearby node or pick one arbitrarily. for (Node node : nodes) { if (node.isNearby()) { return node.getId(); } bestNodeId = node.getId(); } return bestNodeId; }
मैसेज डिलीवर करें
इस्तेमाल करने के लिए नोड की पहचान करने के बाद,
MessageClient
क्लास का इस्तेमाल करके मैसेज भेजें.
इस उदाहरण में, ट्रांसक्रिप्शन की सुविधा वाले नोड में मैसेज भेजने का तरीका बताया गया है इस्तेमाल किया जा सकता है. यह कॉल सिंक्रोनस है और सिस्टम, संदेश को डिलीवरी के लिए कतार में लगा देता है.
ध्यान दें: एक सफल नतीजा कोड, सिर्फ़
तो आपको वह मैसेज दिखाई दे रहा है. अगर आपके ऐप्लिकेशन को डेटा पर भरोसा करना ज़रूरी है, तो
DataItem
का इस्तेमाल करें
ऑब्जेक्ट या ChannelClient
क्लास का इस्तेमाल करें.
Kotlin
const val VOICE_TRANSCRIPTION_MESSAGE_PATH = "/voice_transcription" ... private fun requestTranscription(voiceData: ByteArray) { transcriptionNodeId?.also { nodeId -> val sendTask: Task<*> = Wearable.getMessageClient(context).sendMessage( nodeId, VOICE_TRANSCRIPTION_MESSAGE_PATH, voiceData ).apply { addOnSuccessListener { ... } addOnFailureListener { ... } } } }
Java
public static final String VOICE_TRANSCRIPTION_MESSAGE_PATH = "/voice_transcription"; private void requestTranscription(byte[] voiceData) { if (transcriptionNodeId != null) { Task<Integer> sendTask = Wearable.getMessageClient(context).sendMessage( transcriptionNodeId, VOICE_TRANSCRIPTION_MESSAGE_PATH, voiceData); // You can add success and/or failure listeners, // Or you can call Tasks.await() and catch ExecutionException sendTask.addOnSuccessListener(...); sendTask.addOnFailureListener(...); } else { // Unable to retrieve node with transcription capability } }
ध्यान दें: एसिंक्रोनस और सिंक्रोनस कॉल के बारे में ज़्यादा जानने के लिए, Google Play services और हर सेवा का इस्तेमाल कब करना है, इसके लिए Tasks API देखें.
कनेक्ट किए गए सभी नोड पर मैसेज ब्रॉडकास्ट करने की सुविधा भी ज़रूरी है. सभी को वापस पाने के लिए कनेक्ट किए गए नोड जिन पर मैसेज भेजे जा सकते हैं, ये कोड लागू करें:
Kotlin
private fun getNodes(): Collection<String> { return Tasks.await(Wearable.getNodeClient(context).connectedNodes).map { it.id } }
Java
private Collection<String> getNodes() { HashSet <String>results = new HashSet<String>(); List<Node> nodes = Tasks.await(Wearable.getNodeClient(context).getConnectedNodes()); for (Node node : nodes.getNodes()) { results.add(node.getId()); } return results; }
मैसेज पाएं
आपको मिले मैसेज की सूचना पाने के लिए,
MessageClient.OnMessageReceivedListener
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
का इस्तेमाल करें. इसके बाद, लिसनर को रजिस्टर करें
addListener
के साथ
तरीका. नीचे दिए गए उदाहरण में, लिसनर को इस तरह से इस्तेमाल किया जा सकता है कि
VOICE_TRANSCRIPTION_MESSAGE_PATH
. अगर यह स्थिति
true
, आवाज़ के डेटा को प्रोसेस करने के लिए कोई गतिविधि शुरू करें.
Kotlin
fun onMessageReceived(messageEvent: MessageEvent) { if (messageEvent.path == VOICE_TRANSCRIPTION_MESSAGE_PATH) { val startIntent = Intent(this, MainActivity::class.java).apply { addFlags(Intent.FLAG_ACTIVITY_NEW_TASK) putExtra("VOICE_DATA", messageEvent.data) } startActivity(this, startIntent) } }
Java
@Override public void onMessageReceived(MessageEvent messageEvent) { if (messageEvent.getPath().equals(VOICE_TRANSCRIPTION_MESSAGE_PATH)) { Intent startIntent = new Intent(this, MainActivity.class); startIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); startIntent.putExtra("VOICE_DATA", messageEvent.getData()); startActivity(this, startIntent); } }
इस कोड को लागू करने के बारे में ज़्यादा जानकारी की ज़रूरत है. इसके बारे में जानें पूरी तरह से सुनने वालों की सेवा या गतिविधि को डेटा लेयर के इवेंट को सुनें.