Përmbajtje:
- Hapi 1: Vendosni IBM Watson SDK në Unitet
- Hapi 2: Provoni Tekstin në të folur të IBM Watson
- Hapi 3: Konfiguroni API -në e Kërkimit të personalizuar të Google
- Hapi 4: Vendosni Vuforia në Unitet
- Hapi 5: Krijoni një Parafjalë të Fotografisë
- Hapi 6: Krijoni një Skript për API të Google
- Hapi 7: Krijoni Fabrikën Tonë të Fotografive
- Hapi 8: Ne jemi bërë
2025 Autor: John Day | [email protected]. E modifikuara e fundit: 2025-01-23 15:10
Në këtë Instructable ne do të bëjmë një aplikacion të realitetit të shtuar për Android dhe IOS në Unity3D që përdor API të Google për të kërkuar meme. Ne do të përdorim zbulimin e aeroplanit tokësor të Vuforia në Unity kështu që ky aplikacion celular do të funksionojë për shumicën e përdoruesve të Android dhe IOS. Përdorimi i Vuforia gjithashtu do të na lejojë që fotografitë të jenë të ankoruara në një vendndodhje, në mënyrë që të ecim nëpër këtë fushë të fotografive dhe objektet të qëndrojnë aty ku janë.
Ne gjithashtu do të testojmë API -në e re të IBM Watson, në mënyrë që t'i bëjmë këto kërkime me zërin tonë dhe të përdorim përpunimin e gjuhës së tyre natyrore.
Pra, lajmi i keq është se asnjë nga këto API nuk është plotësisht falas, por lajmi i mirë është se ata të dy janë të lirë të provojnë. API e kërkimit me porosi të Google ju jep 100 kërkime falas në ditë, dhe API IBM Watson ju jep muajin e parë falas.
Me pak fjalë, ky aplikacion do të marrë fjalimin tonë nga mikrofoni në Unity, dërgojeni atë në serverët IBM Watson, të cilët do të na kthejnë tekstin. Ne pastaj do ta marrim atë tekst dhe do ta dërgojmë tek serverët e Google që do të na kthejnë një listë të URL -ve të imazhit në formën JSON.
Hapi 1: Vendosni IBM Watson SDK në Unitet
Për të aktivizuar API -në Watson, së pari duhet të merrni kredencialet tuaja nga faqja e tyre. Shkoni te Console.bluemix.net, krijoni dhe krijoni llogari dhe regjistrohuni. Shkoni te llogaria juaj IBM dhe lundroni te Orgs shkritore cloud dhe krijoni një hapësirë të re. Tani shkoni në pultin tuaj dhe klikoni për të shfletuar shërbimet, shtoni fjalimin në shërbimin e tekstit sepse kjo është ajo që ne do të përdorim. Zgjidhni rajonin, organizatën dhe hapësirën tuaj dhe krijoni projektin. Tani do të shihni kredencialet tuaja API në fund.
Shkarkoni Unity nëse nuk e keni dhe importoni IBM Watson SDK nga dyqani i aseteve në Unity. Ne mund ta provojmë këtë duke krijuar një objekt të zbrazët të lojës dhe ta quajmë IBM Watson dhe të shtojmë shembullin e skriptit të transmetimit. Ky skenar është vendosur tashmë për të regjistruar audio nga uniteti dhe për ta dërguar atë në serverët Watson për përpunim.
Tani për tani ne thjesht do të përdorim këtë skenar shembull sepse kemi shumë më tepër për të bërë, por ndoshta herën tjetër mund të hyjmë më thellë në gjërat e Watson sepse do të doja të bëja diçka me API të Vizionit.
Hapi 2: Provoni Tekstin në të folur të IBM Watson
Ky skenar po kërkon një objekt teksti UI, kështu që le të krijojmë një buton të ri UI, kjo do të na japë tekstin që na nevojitet, ne do ta përdorim butonin më vonë. Vendosni kanavacën në shkallë me madhësinë e ekranit dhe ndryshoni madhësinë e butonit pak. Mbylle atë në pjesën e poshtme të majtë. Tërhiqeni atë tekst në vendin e zbrazët. Hapni skriptin dhe le të shtojmë kredencialet tona të IBM Watson, gjeni se ku përdoret teksti "resultsField" dhe vendoseni në vetëm "alt.transcript" sepse ne do ta përdorim këtë tekst për të kërkuar në Google. Tani, para se ta testojmë këtë, duhet të bëjmë madhësinë e tekstit në mënyrë dinamike, kështu që çfarëdo që themi do të përshtatet brenda kutisë. Kthehuni tek teksti dhe vendoseni në përshtatjen më të mirë. Shkruani një tekst për ta provuar atë. Tani kur klikojmë luajmë fjalët tona do të transkriptohen në tekst nga API Watson Text to Speech.
Hapi 3: Konfiguroni API -në e Kërkimit të personalizuar të Google
Pjesa tjetër që duhet të bëjmë është të vendosim api të kërkimit me porosi të Google për t'u përdorur në Unity. Në një nivel të lartë ne do të bëjmë një kërkesë HTTP nga Unity për serverët e Google e cila do të na kthejë një përgjigje në formatin JSON.
Pra, shkoni te faqja e konfigurimit të Google Custom Search JSON API, klikoni për të marrë një çelës API dhe për të krijuar një aplikacion të ri. Mbaje këtë të hapur. Tani mund të shkojmë te paneli i kontrollit. Vendosni çdo gjë që faqet të kërkojnë, emërtoni çfarëdo dhe klikoni në krijimin.
Klikoni në panelin e kontrollit dhe ju lejon të bëni disa modifikime: ne duam të kërkojmë kryesisht meme dhe të aktivizojmë kërkimin e imazheve. Nën faqet për të kërkuar kalojeni atë në të gjithë uebin. Klikoni përditësimin për të ruajtur gjithçka.
Tani gjeni Google API explorer dhe shkoni te API e kërkimit me porosi. Kjo do të na lejojë të formatojmë përgjigjen JSON që marrim nga Google. Pra, vendosni çdo gjë për pyetjen tani, ngjisni në ID -në e motorit tuaj të kërkimit, vendosni 1 në filtër në mënyrë që të mos marrim kopje, vendosni 10 nën numër sepse ky është numri maksimal i rezultateve që mund të kthejmë në të njëjtën kohë, vendosni imazhin për llojin e kërkimit sepse kjo është gjithçka që duam të kthejmë. Vendosni 1 për fillim dhe në fund nën fushat vendosni "artikuj/lidhje" sepse për secilin artikull të kthyer ne duam vetëm lidhjen e imazhit. Tani kur klikoni ekzekutoni do të shihni që ne marrim 10 lidhje të bukura të imazhit të kthyera.
Tani duhet t'i fusim këto fotografi në Unitet.
Hapi 4: Vendosni Vuforia në Unitet
Lejoni që Vuforia të punojë në mënyrë që të mund të shfrytëzojmë zbulimin e tyre të aeroplanit tokësor. Ruani skenën tuaj aktuale dhe shkoni te cilësimet e ndërtimit. Kaloni platformën tuaj në Android ose IOS dhe nëse në IOS vendosni diçka për identifikuesin e paketës, shtoni një përshkrim të përdorimit të kamerës dhe mikrofonit. Nën cilësimet XR kontrolloni Vuforia të mbështetur nga realiteti i shtuar.
Tani në skenë fshini kamerën kryesore dhe shtoni një Vuforia ARCamera. Shkoni në seksionin e konfigurimit dhe ndryshoni modalitetin e gjurmimit në pozicion. Çiqni të gjitha bazat e të dhënave sepse nuk kemi nevojë për to.
Tani shtoni një zbulues aeroplani dhe ne duhet të anashkalojmë sjelljen e tij të paracaktuar sepse duam të vendosim fazën e aeroplanit tokësor vetëm një herë, kështu që ju lejon të gjeni skenarin Deploy Stage një herë në faqen e internetit të Vuforia. Sillni atë shkrim në Unitet dhe vendoseni në gjetësin e avionit, duke hequr shkrimin e vjetër që ishte atje. Ndryshoni modalitetin në interaktiv dhe sigurohuni që funksioni "OnInteractiveHitTest" të thirret në atë Ngjarje Uniteti. Ndërsa jemi këtu, le të vendosim butonin që kemi bërë më herët në aktiv pasi të kemi gjetur rrafshin tokësor, të vendosim gjendjen e tij të paracaktuar në joaktive. Tani vendosni një aeroplan tokësor në skenë dhe ndryshojeni atë në ajër të mesëm sepse duam që të gjitha fotografitë të notojnë në ajër. Tërhiqeni këtë aeroplan tokësor në vendin e zbrazët në gjetësin e aeroplanit.
Hapi 5: Krijoni një Parafjalë të Fotografisë
Para se të fillojmë t'i bashkojmë të gjitha këto pjesë, ne duhet të krijojmë një objekt të parafabrikuar të lojës që mund ta krijojmë sa herë që ngarkohet një fotografi. Pra, krijoni një objekt të zbrazët të lojës nën fazën e rrafshit tokësor dhe e quani atë "picPrefab". Krijoni një kuadrat si fëmijë dhe shkallëzojeni atë me 2, rrotulloni y -in e tij me 180 gradë në mënyrë që vektori i prindërve përpara, i cili tregohet si një shigjetë blu, të jetë pjesa e përparme e kuadratit.
Krijoni një skenar të ri të quajtur "PictureBehavior" dhe shtojeni atë në picPrefab tonë.
Tani tërhiqeni këtë parafjalë të fotografisë në dosjen tuaj të pasurive dhe kjo është ajo që ne do të vendosim secilën fotografi.
Skenari ynë "PictureBehavior" duhet të duket kështu:
duke përdorur System. Collection;
duke përdorur System. Collections. Generic; duke përdorur UnityEngine; klasë publike PictureBehavior: MonoBehaviour {public Renderer quadRenderer; vektori privat3 i dëshiruarPozicioni; void Fillimi () {// shikoni transformimin e kamerës. Shikoni (Camera.main.transform); Vector3 dëshiruarAngle = i ri Vector3 (0, transform.localEulerAngles.y, 0); transformim.rrotullim = Kuaternion. Euler (Këndi i dëshiruar); // forca në ajër e dëshiruarPozicioni = transformo.pozicioni lokal; transform.localPosition += vektori i ri3 (0, 20, 0); } void Update () {transform.localPosition = Vector3. Lerp (transform.localPosition, dëshiruarPozicioni, Time.deltaTime * 4f); } zbrazëti publike LoadImage (url i vargut) {StartCoroutine (LoadImageFromURL (url)); } IEnumerator LoadImageFromURL (url i vargut) {WWW www = new WWW (url); kthimi i rendimentit www; quadRenderer.material.mainTexture = www.texture; }}
Hapi 6: Krijoni një Skript për API të Google
Tani le të tërheqim referencën për interpretuesin e kuadratit nga "picPrefab" -i ynë.
Na kanë mbetur vetëm dy skripte për të bërë, kështu që le të krijojmë një shkrim C# të quajtur GoogleService.cs dhe PictureFactroy.cs.
Brenda "GoogleService" ngjitni këtë kod që bën kërkesën tonë:
duke përdorur System. Collection;
duke përdorur System. Collections. Generic; duke përdorur UnityEngine; duke përdorur UnityEngine. UI; klasa publike GoogleService: MonoBehaviour {public PictureFactory pictureFactory; butoni i tekstit publikTeksti; string konstitues API_KEY = "VUTN KRYESIN E API -së K !!!!!TU !!!!!"; zbrazëti publike GetPictures () {StartCoroutine (PictureRoutine ()); } IEnumerator PictureRoutine () {buttonText.transform.parent.gameObject. SetActive (false); query string = buttonText.text; query = WWW. EscapeURL (pyetje + "meme"); // fshini imazhet e vjetra pictureFactory. DeleteOldPictures (); // ruani vektorin e kamerës përpara në mënyrë që të mund të lëvizim ndërsa objektet po vendosen Vector3 cameraForward = Camera.main.transform.forward; // ne mund të marrim vetëm 10 rezultate në të njëjtën kohë, kështu që ne duhet të bëjmë lak dhe të ruajmë përparimin tonë duke ndryshuar numrin e fillimit pas çdo 10 int rowNum = 1; për (int i = 1; i <= 60; i + = 10) {string url = "https://www.googleapis.com/customsearch/v1?q=" + pyetje + "& cx = 011535004225295624669%3Afeb1gwic6bs & filter = 1 & num = 10 & searchType = image & start = " + i +" & fushat = artikujt%2Flink & key = " + API_KEY; WWW www = i ri WWW (url); kthimi i rendimentit www; pictureFactory. CreateImages (ParseResponse (www.text), rowNum, cameraForward); rreshtNum ++; } kthimi i rendimentit të ri WaitForSeconds (5f); buttonText.transform.parent.gameObject. SetActive (e vërtetë); } Lista ParseResponse (teksti i vargut) {Lista urlList = lista e re (); string urls = text. Split ('\ n'); foreach (rreshti i vargut në urls) {if (line. Përmban ("link")) {string url = line. Substring (12, line. Gength-13); // filtrimi me png ose jpg nuk duket se funksionon nga Google, kështu që ne e bëjmë këtu: nëse (url. Përmban (".jpg") || url. Përmban (".png")) {urlList. Add (url); }}} urlLista e kthimit; }}
Hapi 7: Krijoni Fabrikën Tonë të Fotografive
Brenda PictureFactory.cs vendosni këtë kod për të krijuar të gjitha fotografitë tona dhe ngarkon teksturat e tyre nga një URL.
duke përdorur System. Collection;
duke përdorur System. Collections. Generic; duke përdorur UnityEngine; klasë publike PictureFactory: MonoBehaviour {public GameObject picPrefab; publike GoogleService googleService; zbrazëti publike DeleteOldPictures () {if (transform.childCount> 0) {foreach (Transformo fëmijën në këtë.transformo) {Destroy (child.gameObject); }}} publiku i pavlefshëm CreateImages (ListurlList, int resultNum, Vector3 camForward) {int picNum = 1; Vector3 center = Camera.main.transform.position; foreach (url string në urlList) {Vector3 pos = GetPosition (picNum, resultNum, camForward); GameObject pic = Instantiate (picPrefab, pos, Quaternion.identity, this.transform); pic. GetComponent (). LoadImage (url); picNum ++; }} Vector3 GetPosition (int picNum, int rowNum, Vector3 camForward) {Vector3 pos = Vector3.zero; nëse (picNum <= 5) {pos = camForward + vector i ri3 (picNum * -3, 0, rowNum * 3.5f); } else {pos = camForward + vector i ri3 ((picNum % 5) * 3, 0, rowNum * 3.5f); } kthimi pos; }}
Hapi 8: Ne jemi bërë
Krijoni objekt lojë të zbrazët të quajtur GoogleService dhe vendosni skriptin "GoogleSerivice" mbi të.
Tërhiqeni skenarin "PictureFactory" në skenën e rrafshit tokësor sepse të gjitha fotografitë tona do të krijohen si fëmijë të këtij objekti të lojës.
Zvarritni referencat e duhura në inspektor, bëni të njëjtën gjë për shërbimin google.
Gjëja e fundit që duhet të bëjmë është të sigurohemi që të thirret funksioni ynë "GetPictures". Pra, le të shkojmë në ngjarjen "onClick" të butonit tonë dhe ta thërrasim nga atje.
Tani mund të klikojmë në play dhe ta provojmë këtë. Sigurohuni që të aktivizoni fazën e rrafshit tokësor dhe butonin. Thuaj një fjalë dhe kliko butonin për të kryer kërkimin në atë tekst!
Tani për ta marrë këtë aplikacion në telefonin tuaj, lidheni atë dhe shkoni te Skedari-> Cilësimet e Ndërtimit. Goditi build and run!
Më tregoni në komente nëse keni ndonjë pyetje!
Recommended:
GlobalARgallery - Galeria Globale e Realitetit të Shtuar: 16 hapa
#GlobalARgallery - Galeria Globale e Realitetit të Shtuar: #GlobalARgaleria është një mundësi që shkollat (dhe të tjerët) të lidhen në mënyrë asinkrone në të gjithë globin dhe të ndajnë përvoja, vepra arti, histori, afate kohore, ekspozita, prezantime dhe çdo gjë tjetër që mund të imagjinoni. Të gjitha këto shfaqen në A
Telefoni i Realitetit të Shtuar: 7 hapa
Telefoni i Realitetit të Shtuar: I lirë, i lehtë, i ftohtë
Mister i Realitetit të Shtuar: 11 hapa
Mister i Realitetit të Shtuar: Lojërat me enigma janë thjesht të mrekullueshme. Ka enigma të të gjitha llojeve, bashkim pjesësh figure tipike, labirint, me shenja dhe madje edhe lojëra video të këtij zhanri (për shembull, Captain Toad). Lojërat me enigma kërkojnë që lojtari të hartojë një strategji për zgjidhjen e problemeve.
Aplikacioni i Realitetit të Shtuar për Fillestarët: 8 Hapa
Aplikacioni i Realitetit të Shtuar për Fillestarët: Ky tutorial do t'ju tregojë se si të bëni një aplikacion të realitetit të shtuar për fillestarët. Ne do të përdorim zbulimin e rrafshit tokësor të Unity3D dhe Vuforia për të bërë një aplikacion AR pa shënues për Android ose IOS. Ne do të kalojmë duke shtuar një model 3D në Unity dhe duke e lëvizur atë në
CityCoaster - Ndërtoni tavën tuaj të realitetit të shtuar për biznesin tuaj (TfCD): 6 hapa (me fotografi)
CityCoaster - Ndërtoni tavën tuaj të realitetit të shtuar për biznesin tuaj (TfCD): Një qytet nën kupën tuaj! CityCoaster është një projekt i lindur duke menduar për një produkt për Aeroportin e Roterdamit të Hagës, i cili mund të shprehë identitetin e qytetit, duke argëtuar klientët e zonës së sallës me realitet të shtuar. Në një mjedis të tillë