Ta og last opp bilder i blandet virkelighet
I denne artikkelen skal vi opprette en app som kan ta bilder i en økt med blandet virkelighet og laste dem opp til en mappe på OneDrive. Vi skal bruke kontrollen Vis i blandet virkelighet i dette eksemplet, med kontrollene Vis form i blandet virkelighet og Målekamera hadde også fungert.
Vi skal dekke følgende oppgaver:
- Legge til kontrollen 3D-objekt i en visning og manipulere et 3D-eksempelobjekt
- koble kontrollen 3D-objekt til kontrollen Vis i blandet virkelighet for å vise 3D-objektet i den virkelige verden
- legge til en gallerikontroll for å vise bilder som er tatt med kontrollen Vis i blandet virkelighet
- laste opp bildene til OneDrive med en Microsoft Power Automate-flyt
- Laste opp bilder tatt i blandet virkelighet til Dataverse
Forutsetning
- Opprett en tom lerretsapp.
- Opprett en mappe kalt MRPhotos på OneDrive. Du skal bruke denne mappen til å lagre de opplastede bildene.
Tips
Kontrollene for blandet virkelighet fungerer best i godt belyste miljøer med overflater med flat tekstur. Sporing er bedre på LIDAR-aktiverte enheter.
Legg til en knapp for å ta et bilde av et 3D-objekt i blandet virkelighet
Dette eksemplet har tre deler. Først skal vi legge til en knapp som gjør at brukerne kan ta et bilde av et 3D-objekt i blandet opplevelse.
Sette inn en 3D-objekt-kontroll
Gjør følgende med appen åpen for redigering i Power Apps Studio:
Åpne Sett inn-fanen, og utvid Medier.
Velg 3D object for å plassere et 3D-objekt på appskjermen. Dra kontrollen til skjermen for å plassere den mer nøyaktig.
Kontrollen leveres med en gjennomsiktig kubeform. Hvis du vil, kan du endre egenskapen Kilde for kontrollen for å laste inn en annen 3D-modell. I dette eksemplet skal vi bruke nettadressen https://raw.githubusercontent.com/microsoft/experimental-pcf-control-assets/master/robot_arm.glb.
Sett inn og koble til kontrollen Vis i blandet virkelighet
Åpne Sett inn-fanen, og utvid Blandet virkelighet.
Velg Vis i blandet virkelighet for å plassere kontrollen på appskjermen, eller dra kontrollen til skjermen for å plassere den mer nøyaktig.
Endre egenskapen Kilde for kontrollen til 3DObject1.Source. (3DObject1 er navnet på kontrollen 3D-objekt vi la til tidligere.) Dette uttrykket angir at kontrollen Vis i blandet virkelighet skal legge 3D-modellen over kamerafeeden på enheten.
Velg View in MR for å vise 3D-objektet i blandet virkelighet. Velg kameraikonet for å ta et bilde i visningen for blandet virkelighet.
Sett inn en gallerikontroll for å vise bilder som er tatt i appen
Vi skal deretter legge til et galleri, slik at brukere kan vise bildene de har tatt.
Rediger appen på nytt. Åpne Sett inn-fanen, og plasser kontrollen Vertical gallery på skjermen.
Endre egenskapen Items for kontrollen til ViewInMR1.Photos. (ViewInMR1 er navnet på kontrollen Vis i blandet virkelighet vi la til tidligere.)
Du kan alternativt endre egenskapen Layout for galleriet til Image and title.
Forhåndsvis appen, og velg View in MR for å generere et eksempelbilde. Galleriet fylles ut med et eksempelbilde.
Obs!
Hvis brukere går ut av visningen for blandet virkelighet for å se galleriet og deretter går inn i visningen for blandet virkelighet på nytt for å ta flere bilder, blir de tidligere bildene erstattet av de nye.
Legg til et større overlegg i miniatyrbildene i biblioteket
Du kan gjøre det lettere å se bildene i galleriet ved å legge til et overlegg i full størrelse som vises når brukeren velger et miniatyrbilde.
Rediger appen på nytt. Åpne Sett inn-fanen, og utvid Medier.
Velg Bilde for å plassere en bildekontroll på skjermen. Du kan flytte det og endre størrelsen på det alt etter hvordan du vil at det større bildet skal vises når miniatyrbildet velges.
Endre egenskapen for bildekontrollen som følger: | Egenskap | Verdi | | - | - | | OnSelect | UpdateContext({vVisibleImageZoom:false}) | | Image | Gallery1.Selected.Image2 (forutsatt at gallerikontrollen er Gallery1 og det første miniatyrbildet er Image2) | Visible | vVisibleImageZoom
Velg det første miniatyrbildet i gallerikontrollen. Endre egenskapen OnSelect for det til UpdateContext({vVisibleImageZoom:true}).
Velg View in MR, og velg deretter kameraikonet for å ta et bilde. Velg Tilbake-pilen øverst på skjermen for å gå ut av visningen for blandet virkelighet.
Velg miniatyrbildet i galleriet for å vise en større versjon av bildet. Velg bildet for å skjule det.
Last opp bilder til OneDrive med en Power Automate-flyt
Til slutt skal vi opprette en arbeidsflyt ved hjelp av Power Automate-ruten. Arbeidsflyten laster opp bilder fra appen til en mappe kalt MRPhotos på OneDrive.
Opprett en flyt i Power Automate
Rediger appen. På menyen for appredigering velger du Power Automate > Opprett ny flyt.
Søk etter og velg Power Apps-knappmalen.
I vinduet Opprett flyten velger du Rediger i avansert modus.
Velg Power Apps-knapp øverst i vinduet, og angi et nytt navn for flyten. I dette eksemplet skal vi kalle flyten Last opp bilde fra blandet virkelighet.
Velg Power Apps-knapp øverst i vinduet, og angi et nytt navn for flyten. I dette eksemplet skal vi kalle flyten Last opp bilde fra blandet virkelighet.
Søk etter PowerApps (V2) og velg utløseren PowerApps (V2).
Velg Legg til inndata, og velg deretter Fil.
Endre etiketten Filinnhold til Bilde.
Velg Nytt trinn. Søk etter OneDrive – Opprett fil, og velg handlingen Opprett fil.
Velg mappeikonet i Mappebane, og gå til MRPhotos-mappen du opprettet tidligere.
Skriv inn @{triggerBody()?['file']?['name']} i Filnavn (Teksten endres til «file.name.»)
Skriv inn @{triggerBody()['file']['contentBytes']} i Filinnhold (Teksten endres til «Bilde.»)
Lagre flyten.
Den fullstendige flyten skal se slik ut:
Koble arbeidsflyten til en knapp i appen
Gå tilbake til appen i Power Apps Studio. Flyten vises nå under Tilgjengelige flyter.
Åpne Sett inn-fanen og velg Knapp. Plasser knappekontrollen på skjermen, og endre størrelsen på den etter behov.
Endre egenskapen Text for knappekontrollen til Upload photos.
Velg egenskapen OnSelect på formellinjen øverst i Power Apps-vinduet. Velg Handling > Power Automate > Last opp bilde fra blandet virkelighet.
Egenskapen OnSelect for knappekontrollen endres til UploadMRPhoto.Run(.
Hvis du vil laste opp det siste bildet som er tatt, limer du inn følgende kode etter den innledende parentesen: {file:{name:GUID() & ".png", contentBytes:Last(ViewInMR1.Photos).ImageURI}})
Hvis du plasserte knappekontrollen i galleriet, limer du inn følgende kode i stedet: {file: {name:GUID() & ".png", contentBytes:ThisItem.ImageURI}})
Hvis du vil at knappen skal laste opp alle bilder som er tatt, sletter du UploadMRPhoto.Run( og limer inn følgende kode: ForAll(ViewInMR1.Photos, UploadMRPhoto.Run({file:{name:GUID() & ".png", contentBytes:ImageURI}}))
Forhåndsvis appen, velg View in MR, og velg deretter Last opp bilder. Se MRPhotos-mappen på OneDrive, og bekreft at eksempelbildet er lastet opp.
Legg til funksjon for frakoblet modus i appen
Du kan bruke appen selv når du har begrenset eller ingen nettverkstilkobling, ved hjelp av funksjonene SaveData og LoadData.
Last opp bilder tatt i blandet virkelighet til Dataverse
Du kan legge til bilder i Dataverse-tabeller via en kolonne med datatypen Bilde. Bildekolonner i Dataverse har to obligatoriske felt – Full og Verdi, som kan angis til ImageURI-utdataene for MR-kontrollene.
Hvis du for eksempel vil laste opp det første bildet som er tatt av kontrollen Påslag i blandet virkelighet, til en Dataverse-kolonne kalt Bilde:
Image: {Full: First(MarkupInMR.Photos).ImageURI, Value: First(MarkupInMR.Photos).ImageURI}
Se også
Obs!
Kan du fortelle oss om språkinnstillingene for dokumentasjonen? Ta en kort undersøkelse. (vær oppmerksom på at denne undersøkelsen er på engelsk)
Undersøkelsen tar rundt sju minutter. Det blir ikke samlet inn noen personopplysninger (personvernerklæring).