Läheisyysvalokuvien jakaminen IOS -sovellus: 6 vaihetta
Läheisyysvalokuvien jakaminen IOS -sovellus: 6 vaihetta
Anonim

Tässä ohjeessa luomme Swift -sovelluksen iOS -sovellukselle, jonka avulla voit jakaa valokuvia kaikkien lähellä olevien kanssa ilman, että laiteparia tarvitaan.

Käytämme Chirp Connectia tietojen lähettämiseen äänen avulla ja Firebasen avulla kuvien tallentamiseen pilveen.

Tietojen lähettäminen äänellä luo ainutlaatuisen kokemuksen, jossa tiedot voidaan lähettää kaikille kuuloalueella oleville.

Vaihe 1: Asennusvaatimukset

Xcode

Asenna App Storesta.

Kaakaopodit

sudo helmi asentaa cocoapodit

Chirp Connect iOS SDK

Rekisteröidy osoitteessa admin.chirp.io

Vaihe 2: Asennusprojekti

1. Luo Xcode -projekti.

2. Kirjaudu Firebaseen ja luo uusi projekti.

Ota Firestore käyttöön napsauttamalla Tietokanta -osiota ja valitsemalla Cloud Firestore. Napsauta Toiminnot ottaaksesi myös pilvitoiminnot käyttöön.

3. Suorita Projektin yleiskatsaus -sivulla Asenna iOS -sovelluksesi

Tarvitset Xcode -projektiasetusten Yleiset -välilehden Bundle Identifier -ohjelman. Kun Podfile on luotu, sinun on lisättävä seuraavat riippuvuudet ennen pod -asennuksen suorittamista.

# Palot projektille

pod 'Firebase/Core' pod 'Firebase/Firestore' pod 'Firebase/Storage'

4. Lataa uusin Chirp Connect iOS SDK osoitteesta admin.chirp.io/downloads

5. Integroi Chirp Connect Xcodeen noudattamalla sivuston Developers.chirp.io ohjeita.

Siirry aloitusoppaaseen / iOS. Vieritä sitten alas ja noudata Swiftin asennusohjeita. Tämä edellyttää kehyksen tuomista ja siltaotsikon luomista.

Nyt asennus on valmis, voimme aloittaa jonkin koodin kirjoittamisen! On hyvä tarkistaa projektisi rakenteet asennuksen jokaisessa vaiheessa.

Vaihe 3: Kirjoita IOS -koodi

1. Tuo Firebase ViewControlleriin ja laajenna NSData sisältämään hexString -laajennus, jotta voimme muuntaa Chirp Connect -hyötykuormat heksadesimaalijonoksi. (Chirp Connect on saatavilla maailmanlaajuisesti siltaotsikon ansiosta).

Tuo UIKit

tuoda Firebasen

laajennustiedot {

var hexString: Jono {return map {String (format: "%02x", UInt8 ($ 0))}.joined ()}}

2. Lisää ImagePicker -edustajat ViewControlleriin ja ilmoita ChirpConnect -muuttuja nimeltä connect.

luokan ViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate {

var connect: ChirpConnect? ohita funktionäkymäDidLoad () {super.viewDidLoad ()…

3. Alusta Super.viewDidLoad -ohjelman jälkeen Chirp Connect ja määritä vastaanotettu takaisinsoitto. Vastaanotetussa takaisinsoitossa haemme kuvan Firebasesta käyttämällä vastaanotettua hyötykuormaa ja päivitämme ImageView -näkymän. Voit noutaa APP_KEY- ja APP_SECRET -osoitteet admin.chirp.io.

connect = ChirpConnect (appKey: APP_KEY jaSecret: APP_SECRET) if let connect = connect {connect.getLicenceString {(lisenssi: String ?, error: Error?) in if error == nil {if let license = license {connect.setLicenceString (lisenssi) connect.start () connect.receivedBlock = {(data: Data?) -> () in if let data = data {print (String (muoto: "Vastaanotetut tiedot: %@", data.hexString)) anna tiedosto = Storage.storage (). Reference (). Child (data.hexString) file.getData (maxSize: 1 * 1024 * 2048) {imageData, error in if let error = error {print ("Error: %@", error.localizedDescription)} else {self.imageView.image = UIImage (data: imageData!)}}}} {print ("Dekoodaus epäonnistui"); }}}}

4. Lisää nyt koodi lähettääksesi kuvatiedot, kun ne on valittu käyttöliittymässä.

func imagePickerController (_ valitsin: UIImagePickerController, didFinishPickingMediaWithInfo info: [String: Any])

{anna imageData = info [UIImagePickerControllerOriginalImage] nimellä? UIImage let data: Data = UIImageJPEGRepresentation (imageData !, 0,1)! self.imageView.image = imageData let metadata = StorageMetadata () metadata.contentType = "image/jpeg" if let connect = connect {anna avain: Data = connect.randomPayload (withLength: 8) Firestore.firestore (). collection (" addDocument (data: ["key": key.hexString, "timestamp": FieldValue.serverTimestamp ()]) {error in if let error = error {print (error.localizedDescription)}} Storage.storage ().reference (). child (key.hexString).putData (data, metadata: metadata) {(metatiedot, virhe) in if let error = error {print (error.localizedDescription)}} muu {connect.send (key)}} } self.dismiss (animoitu: totta, viimeistely: nolla)}

Huomautus: Sinun on lisättävä tietosuoja - valokuvakirjaston käyttökuvaus, tietosuoja - valokuvakirjaston käytön kuvaus ja tietosuoja - mikrofonin käytön kuvaus -lausunnot Info.plistisi, jotta voit antaa kameran, valokuvakirjaston ja mikrofonin käyttöoikeudet.

Vaihe 4: Luo käyttöliittymä

Luo käyttöliittymä
Luo käyttöliittymä

Siirry nyt Main.storyboard -tiedostoon ja luo käyttöliittymä.

1. Vedä ImageView'n ja kahden painikkeen yli kuvakäsikirjoitukseen oikeassa alakulmassa olevasta Object Library -paneelista.

2. Lisää kullekin painikkeelle noin 75 pikselin korkeusrajoitus valitsemalla komponentti ja napsauttamalla Lisää uusia rajoituksia -painiketta (joka näyttää Star Wars tiehävittäjältä). Syötä sitten korkeus ja paina Enter.

3. Valitse kaikki kolme osaa ja aseta ne pinonäkymään napsauttamalla Upota pinoon -painiketta.

4. Avaa nyt Assistant Editor ja paina CTRL -näppäintä ja vedä kustakin komponentista ViewController -koodiin luodaksesi pistorasiat kullekin komponentille.

@IBOutlet var imageView: UIImageView!

@IBOutlet var openLibraryButton: UIButton! @IBOutlet var openCameraButton: UIButton!

5. Luo nyt toiminto kameran/kirjaston käyttöliittymän avaamiseksi painamalla CTRL -näppäintä ja vetämällä molemmista painikkeista.

6. Lisää seuraava kirjasto Avaa kirjasto -toiminnossa

@IBAction func openLibrary (_ lähettäjä: mikä tahansa) {

anna imagePicker = UIImagePickerController () imagePicker.delegate = itse; imagePicker.sourceType =.photoLibrary self.present (imagePicker, animoitu: tosi, viimeistely: nolla)}

7. Avaa kamera -toiminnossa

@IBAction func openCamera (_ lähettäjä: mikä tahansa) {

anna imagePicker = UIImagePickerController () imagePicker.delegate = self imagePicker.sourceType =.kamera; self.present (imagePicker, animoitu: tosi, viimeistely: nolla)}

Vaihe 5: Kirjoita pilvitoiminto

Koska valokuvia ei tarvitse tallentaa pilveen ikuisesti, voimme kirjoittaa pilvitoiminnon puhdistusta varten. Tämän voi käynnistää HTTP-funktiona joka tunti cron-palvelu, kuten cron-job.org.

Ensinnäkin meidän on asennettava firebase-työkalut

npm asenna -g firebase -tools

Suorita sitten projektin juurihakemisto

firebase init

Alusta pilvitoiminnot valitsemalla toiminnot komentoriviltä. Voit myös ottaa firestoren käyttöön, jos haluat myös määrittää Firestoren.

Avaa sitten toiminnot/index.js ja lisää seuraava koodi. Muista vaihtaa

Firebase -projektitunnukseesi.

const-toiminnot = vaativat ('firebase-Functions');

const admin = vaatii ('firebase-admin'); admin.initializeApp () export.cleanup = features.https.onRequest ((pyyntö, vastaus) => {admin.firestore ().collection ('uploads').where ('timestamp', '{snapshot.forEach (doc =) > {admin.storage ().bucket ('gs: //.appspot.com').file (doc.data ().key).delete () doc.ref.delete ()}) return response.status (200). Lähetä ('OK')}). Saalis (err => vastaus. Tila (500). Lähetä (virhe))});

Pilvitoimintojen käyttöönotto on yhtä helppoa kuin tämän komennon suorittaminen.

paloaseman käyttöönotto

Luo sitten osoitteessa cron-job.org tehtävä, joka käynnistää tämän päätepisteen joka tunti. Päätepiste on jotain sellaista

us-central1-project_id.cloudfunctions.net/cleanup

Vaihe 6: Suorita sovellus

Suorita sovellus simulaattorilla tai iOS -laitteella ja aloita valokuvien jakaminen!

Suositeltava: