आपके डिवाइस में कुछ ऐसी खास क्षमताएं हो सकती हैं जो मौजूदा सेट में शामिल न हों विशेषताएं -- जैसे कि "मेरी लाइट जलाओ" यह एक ऐसे डिवाइस की विशेषता है जो अपनी रोशनी ब्लिंक कर सकता है. आपने लोगों तक पहुंचाया मुफ़्त में आपके डिवाइस के लिए ऐसी कस्टम कार्रवाइयाँ बना सकता है जो कुछ खास क्षमताओं को ट्रिगर करने के लिए आपके डिवाइस का इस्तेमाल किया जा सकता है.
कस्टम डिवाइस कार्रवाई तय करने के लिए, आपको इनकी ज़रूरत होगी:
- उपयोगकर्ता क्वेरी से मिलान करने वाला पैटर्न
- मिलती-जुलती क्वेरी के साथ जोड़ने के लिए कस्टम डिवाइस कार्रवाई
- अगर डिवाइस कार्रवाई का समर्थन करता है, तो उपयोगकर्ता को वापस बोला गया लेख
- किसी निर्देश का नाम, जो सभी पैरामीटर के साथ आपके डिवाइस पर वापस भेजा जाता है
इस जानकारी को ऐक्शन पैकेज शामिल है. ऐक्शन पैकेज में, Assistant से मिलने वाले जवाबों का फ़ॉर्मैट तय किया जाता है. इसे नापसंद करें Actions SDK टूल और डिवाइस के हिसाब से की जाने वाली कार्रवाइयां, स्थानीय तौर पर पूरी की जाती हैं; आप इसे एंडपॉइंट का इस्तेमाल करें, ताकि अनुरोधों को प्रोसेस किया जा सके और जवाब दिया जा सके. कस्टम डिवाइस कार्रवाइयां बातचीत नहीं करनी चाहिए.
कोई ऐक्शन पैकेज बनाएं
नीचे दिए गए उदाहरण का इस्तेमाल करके, एक फ़ाइल बनाएं (जैसे कि actions.json
)
टेस्ट कमांड के बारे में बताता है: एलईडी को ब्लिंक करना.
उस सैंपल कोड से फ़ाइल कॉपी करें जिसका आपने इस्तेमाल किया है
पिछले चरण में डाउनलोड किया गया है:
cd assistant-sdk-python/google-assistant-sdk/googlesamples/assistant/library/
cp ~/assistant-sdk-python/google-assistant-sdk/actions.json .
{
"manifest": {
"displayName": "Blinky light",
"invocationName": "Blinky light",
"category": "PRODUCTIVITY"
},
"actions": [
{
"name": "com.example.actions.BlinkLight",
"availability": {
"deviceClasses": [
{
"assistantSdkDevice": {}
}
]
},
"intent": {
"name": "com.example.intents.BlinkLight",
"parameters": [
{
"name": "number",
"type": "SchemaOrg_Number"
},
{
"name": "speed",
"type": "Speed"
}
],
"trigger": {
"queryPatterns": [
"blink ($Speed:speed)? $SchemaOrg_Number:number times",
"blink $SchemaOrg_Number:number times ($Speed:speed)?"
]
}
},
"fulfillment": {
"staticFulfillment": {
"templatedResponse": {
"items": [
{
"simpleResponse": {
"textToSpeech": "Blinking $number times"
}
},
{
"deviceExecution": {
"command": "com.example.commands.BlinkLight",
"params": {
"speed": "$speed",
"number": "$number"
}
}
}
]
}
}
}
}
],
"types": [
{
"name": "$Speed",
"entities": [
{
"key": "SLOWLY",
"synonyms": [
"slowly",
"slow"
]
},
{
"key": "NORMALLY",
"synonyms": [
"normally",
"regular"
]
},
{
"key": "QUICKLY",
"synonyms": [
"quickly",
"fast",
"quick"
]
}
]
}
]
}
कस्टम डिवाइस तय करने के लिए, ऊपर दिए गए उदाहरण में नीचे दी गई जानकारी का इस्तेमाल किया गया है कार्रवाई:
- उपयोगकर्ता क्वेरी से मैच करने वाला पैटर्न (N बार ब्लिंक करें)
- मिलती-जुलती क्वेरी (
com.example.actions.BlinkLight
) से जोड़ने के लिए, डिवाइस की कस्टम कार्रवाई संगठन से जुड़े कामों के लिए - अगर डिवाइस कार्रवाई का समर्थन करता है, तो उपयोगकर्ता को वापस बोला गया लेख (N बार ब्लिंक करता है)
- निर्देश का नाम (
com.example.commands.BlinkLight
) जिसे वापस भेजा गया है डिवाइस और उसमें मौजूद अन्य पैरामीटर (संख्या और स्पीड की जानकारी)
क्वेरी पैटर्न तय करने के लिए, इन बातों का ध्यान रखें:
- schema.org के तय किए गए टाइप इस्तेमाल किए जा सकते हैं डालें.
types [...]
अरे, कस्टम टाइप की सूची के बारे में बताता है (उदाहरण के लिए,$Speed
).- क्वेरी पैटर्न में कस्टम टाइप का इस्तेमाल किया जा सकता है. उपयोगकर्ता इनमें से कोई भी बोल सकता है समानार्थी शब्द शामिल करें.
- जब कोई समानार्थी शब्द मेल खाता है, तो टाइप इंस्टेंस (
speed
) नॉर्मलाइज़ की गई कुंजी (SLOWLY
) देगा. एक से ज़्यादा इकाई हो सकती हैं: उदाहरण के लिए, यहां अलग-अलग लाइटें हैं जो अलग-अलग रफ़्तार पर काम करती हैं पलक झपकते ही. - अनुरोध के टीटीएस पैटर्न के कुछ हिस्से ज़रूरी नहीं हो सकते हैं. उदाहरण के लिए,
इस हिस्से को वैकल्पिक बनाने के लिए, क्वेरी पैटर्न में
($Speed:speed)?
. $type.raw
(उदाहरण के लिए,$speed.raw
) जवाब टीटीएस को उस शब्द(शब्दों) से बदल दिया जाता है, जिसे उपयोगकर्ता ने असल में बोला है.
इनमें से कई फ़ील्ड की जानकारी के लिए, देखें ActionPackage दस्तावेज़.
ऐक्शन पैकेज डिप्लॉय करें
कार्रवाई पैकेज में अपनी कस्टम डिवाइस कार्रवाई बनाने के बाद, आप कार्रवाई पैकेज को Assistant ऐक्सेस कर सकती है.
अपने डिवाइस पर इस सेक्शन में दिए गए चरणों को पूरा किया जा सकता है. हालांकि, यह ज़्यादा आसान हो सकता है उसका इस्तेमाल, अपने डेवलपमेंट सिस्टम पर कर सकते हैं. इन निर्देशों का पालन करने के लिए, चलाने के लिए वर्चुअल एनवायरमेंट का इस्तेमाल करें.
gactions
कमांड लाइन टूल डाउनलोड करें.gactions
वाली डायरेक्ट्री से सभी मौजूदा क्रेडेंशियल हटाएं टूल.rm creds.data
gactions
सीएलआई का इस्तेमाल करके, ऐक्शन पैकेज को Google पर सेव करें.project_id
को अपने Actions Console प्रोजेक्ट से बदलें आईडी../gactions update --action_package actions.json --project project_id
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया हैपहली बार इस निर्देश को चलाने पर, आपको एक यूआरएल दिया जाएगा और आपसे साइन इन करें. यूआरएल को कॉपी करें और उसे ब्राउज़र में चिपकाएं. ऐसा किसी भी सिस्टम पर किया जा सकता है. पेज पर आपको अपने Google खाते में साइन इन करने के लिए कहा जाएगा. हस्ताक्षर करें उस Google खाते में लिंक है जिससे प्रोजेक्ट बनाया गया था अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है step पर टैप करें.
एपीआई से मिला अनुमति का अनुरोध स्वीकार किए जाने के बाद, आपको एक कोड दिखेगा जैसे कि "4/XXXX". इस कोड को कॉपी करके यहां चिपकाएं टर्मिनल:
Enter the authorization code:
अनुमति मिलने के बाद, आपको इससे मिलता-जुलता जवाब दिखेगा निम्न:
Your app for the Assistant for project my-devices-project was successfully updated with your actions.
gactions
सीएलआई का इस्तेमाल करके, अपने ऐक्शन पैकेज को टेस्ट मोड में डिप्लॉय करें. आपको अपने ऐक्शन पैकेज को, पहले से ही कम से कम एक बार Google पर सेव करना होगा इस आदेश को चला रहा है. परीक्षण मोड आपके उपयोगकर्ता खाते के लिए उपलब्ध है../gactions test --action_package actions.json --project project_id
फ़िलहाल, ऐक्शन सिम्युलेटर का इस्तेमाल करके प्रोजेक्ट की जांच नहीं की जा सकती.
Action पैकेज को अपडेट करने के लिए,
gactions update
निर्देश का इस्तेमाल करें.(ज़रूरी नहीं) स्थानीय भाषा में कार्रवाई वाले पैकेज बनाए जा सकते हैं कई अलग-अलग भाषाओं और स्थान-भाषाओं के साथ काम करता है एक ही प्रोजेक्ट में एक साथ रिकॉर्ड करें.
सैंपल में बदलाव करना
डिवाइस पर इस सेक्शन में दिया गया तरीका अपनाएं.
nano hotword.py
अपनी कस्टम कार्रवाई के लिए हैंडलर जोड़ें. अगर आप चाहें, तो नीचे दिए गए हैंडलर का इस्तेमाल किया जा सकता है आप ऊपर दिया गया, कार्रवाई पैकेज का इस्तेमाल कर सकते हैं.
import time # Add this to the imports near the top of the file ... if event.type == EventType.ON_DEVICE_ACTION: for command, params in event.actions: print('Do command', command, 'with params', str(params)) # Add the following lines after the existing line above: if command == "com.example.commands.BlinkLight": number = int( params['number'] ) for i in range(int(number)): print('Device is blinking.') # GPIO.output(25, 1) time.sleep(1) # GPIO.output(25, 0) time.sleep(1)
सैंपल चलाएं
बदला गया सोर्स कोड चलाएं.
python hotword.py --device-model-id my-model
कोई क्वेरी आज़माएं. ऊपर दिए गए उदाहरण के लिए, नीचे दिया गया तरीका आज़माएं:
Ok Google, पांच बार ब्लिंक करें.
ध्यान दें कि क्वेरी का मिलान, कार्रवाई पैकेज के क्वेरी पैटर्न से होना चाहिए.