Daftar Isi:
2025 Pengarang: John Day | [email protected]. Terakhir diubah: 2025-01-23 14:49
Dalam instruksi ini, kami akan membuat aplikasi iOS dengan Swift yang memungkinkan Anda berbagi foto dengan siapa pun di sekitar, tanpa perlu memasangkan perangkat.
Kami akan menggunakan Chirp Connect untuk mengirim data menggunakan suara, dan Firebase untuk menyimpan gambar di cloud.
Mengirim data dengan suara menciptakan pengalaman unik di mana data dapat disiarkan ke siapa saja dalam jangkauan pendengaran.
Langkah 1: Instal Persyaratan
Kode X
Instal dari App Store.
CocoaPods
Sudo gem install cocoapods
Chirp Connect iOS SDK
Daftar di admin.chirp.io
Langkah 2: Siapkan Proyek
1. Buat proyek Xcode.
2. Masuk ke Firebase dan buat proyek baru.
Aktifkan Firestore dengan mengklik bagian Database dan memilih Cloud Firestore. Klik ke Fungsi untuk juga mengaktifkan Cloud Functions.
3. Jalankan melalui Siapkan aplikasi iOS Anda di halaman Ikhtisar Proyek
Anda akan memerlukan Bundle Identifier dari Tab Umum di Pengaturan Proyek Xcode Anda. Setelah Podfile dibuat, Anda perlu menambahkan dependensi berikut, sebelum menjalankan pod install.
# Pod untuk proyek
pod 'Firebase/Core' pod 'Firebase/Firestore' pod 'Firebase/Storage'
4. Unduh Chirp Connect iOS SDK terbaru dari admin.chirp.io/downloads
5. Ikuti langkah-langkah di developers.chirp.io untuk mengintegrasikan Chirp Connect ke Xcode.
Pergi ke Memulai / iOS. Kemudian gulir ke bawah dan ikuti petunjuk penyiapan Swift. Ini akan melibatkan mengimpor kerangka kerja dan membuat header penghubung.
Sekarang setup selesai, kita bisa mulai menulis beberapa kode! Sebaiknya periksa build proyek Anda di setiap tahap dalam penyiapan.
Langkah 3: Tulis Kode IOS
1. Impor Firebase ke ViewController Anda dan perluas NSData untuk menyertakan ekstensi hexString, sehingga kami dapat mengonversi payload Chirp Connect ke string heksadesimal. (Chirp Connect akan tersedia secara global berkat bridging header).
impor UIKit
impor Firebase
ekstensi Data {
var hexString: String { kembali peta { String(format: "%02x", UInt8($0)) }.joined() } }
2. Tambahkan delegasi ImagePicker ke ViewController Anda, dan nyatakan variabel ChirpConnect yang disebut connect.
kelas ViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate {
var terhubung: ChirpConnect? menimpa fungsi viewDidLoad() { super.viewDidLoad() …
3. Setelah super.viewDidLoad, inisialisasi Chirp Connect, dan atur panggilan balik yang diterima. Dalam panggilan balik yang diterima, kami akan mengambil gambar dari Firebase menggunakan payload yang diterima dan memperbarui ImageView. Anda bisa mendapatkan APP_KEY dan APP_SECRET dari admin.chirp.io.
connect = ChirpConnect(appKey: APP_KEY, andSecret: APP_SECRET) if let connect = connect { connect.getLicenceString { (licence: String?, error: Error?) in if error == nil { if let license = license { connect.setLicenceString(licence) connect.start() connect.receivedBlock = { (data: Data?) -> () in if let data = data { print(String(format: "Received data: %@", data.hexString)) let file = 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!) } } } else { print("Decode gagal"); } } } }
4. Sekarang tambahkan kode untuk mengirim data gambar setelah dipilih di UI.
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String: Any])
{ biarkan imageData = info[UIImagePickerControllerOriginalImage] sebagai? UIImage biarkan data: Data = UIImageJPEGRepresentation(imageData!, 0.1)! self.imageView.image = imageData let metadata = StorageMetadata() metadata.contentType = "image/jpeg" jika let connect = connect { let key: Data = connect.randomPayload(withLength: 8) Firestore.firestore().collection(" uploads").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) { (metadata, error) in if let error = error { print(error.localizedDescription) } else { connect.send(key) } } } self.dismiss(animasi: true, complete: nil) }
Catatan: Anda perlu menambahkan Pernyataan Privasi - Deskripsi Penggunaan Perpustakaan Foto, Privasi - Deskripsi Penggunaan Perpustakaan Foto dan Privasi - Deskripsi Penggunaan Mikrofon ke Info.plist Anda untuk memberikan izin penggunaan Kamera, Perpustakaan Foto, dan Mikrofon.
Langkah 4: Buat Antarmuka Pengguna
Sekarang buka file Main.storyboard untuk membuat UI.
1. Seret melintasi ImageView dan dua Tombol ke Storyboard dari panel Object Library di sudut kanan bawah.
2. Untuk setiap tombol tambahkan batasan ketinggian sekitar 75px dengan memilih komponen dan klik tombol Tambahkan Batasan Baru (yang terlihat seperti petarung dasi Star Wars), lalu masukkan ketinggian dan tekan Enter.
3. Pilih ketiga komponen dan letakkan dalam tampilan tumpukan dengan mengklik tombol Sematkan Dalam Tumpukan.
4. Sekarang buka Asisten Editor, dan tekan CTRL dan seret dari setiap komponen ke kode ViewController, untuk membuat Outlet untuk setiap komponen.
@IBOutlet var imageView: UIImageView!
@IBOutlet var openLibraryButton: UIButton! @IBOutlet var openCameraButton: UIButton!
5. Sekarang CTRL dan seret dari kedua tombol untuk membuat Action untuk membuka UI kamera/perpustakaan.
6. Pada action Open Library, tambahkan kode berikut
@IBAction func openLibrary(_ sender: Any) {
biarkan imagePicker = UIImagePickerController() imagePicker.delegate = self; imagePicker.sourceType =.photoLibrary self.present(imagePicker, animasi: true, penyelesaian: nil) }
7. Dalam aksi Buka Kamera
@IBAction func openCamera(_ sender: Any) {
biarkan imagePicker = UIImagePickerController() imagePicker.delegate = self imagePicker.sourceType =.camera; self.present(imagePicker, animasi: true, penyelesaian: nil) }
Langkah 5: Tulis Fungsi Cloud
Karena foto tidak perlu disimpan di cloud selamanya, kita dapat menulis Cloud Function untuk melakukan pembersihan. Ini dapat dipicu sebagai fungsi HTTP setiap jam oleh layanan cron seperti cron-job.org.
Pertama-tama kita perlu menginstal firebase-tools
npm install -g firebase-tools
Kemudian dari direktori root proyek, jalankan
firebase init
Pilih fungsi dari baris perintah untuk menginisialisasi fungsi cloud. Anda juga dapat mengaktifkan firestore jika Anda ingin juga mengonfigurasi Firestore.
Kemudian buka functions/index.js dan tambahkan kode berikut. Ingatlah untuk berubah
ke id proyek Firebase Anda.
const fungsi = membutuhkan('firebase-fungsi');
const admin = membutuhkan('firebase-admin'); admin.initializeApp() export.cleanup = functions.https.onRequest((request, response) => { admin.firestore().collection('uploads').where('timestamp', ' { snapshot.forEach(doc = > { admin.storage().bucket('gs://.appspot.com').file(doc.data().key).delete() doc.ref.delete() }) mengembalikan response.status(200).send('OK') }).catch(err => respon.status(500).send(err)) });
Menyebarkan fungsi cloud semudah menjalankan perintah ini.
penyebaran firebase
Kemudian di cron-job.org buat pekerjaan untuk memicu titik akhir ini setiap jam. Titik akhir akan menjadi sesuatu seperti
us-central1-project_id.cloudfunctions.net/cleanup
Langkah 6: Jalankan Aplikasi
Jalankan aplikasi di simulator atau perangkat iOS, dan mulailah berbagi foto!
Direkomendasikan:
Solusi IOT untuk Sepeda Berbagi: 6 Langkah
Solusi IOT untuk Sepeda Berbagi: Sepeda berbagi sangat populer di Cina akhir-akhir ini. Ada lebih dari 10 merek sepeda berbagi di pasaran, dan “mobike” adalah yang paling terkenal, memiliki lebih dari 100 juta pengguna terdaftar, dan telah menyebar ke kota-kota lain t
Aplikasi Android/iOS untuk Mengakses Router OpenWrt Anda dari Jarak Jauh: 11 Langkah
Aplikasi Android/iOS untuk Mengakses Router OpenWrt Anda dari Jarak Jauh: Saya baru saja membeli router baru (Xiaomi Mi Router 3G). Dan tentu saja, perangkat keras baru yang mengagumkan ini mengilhami saya untuk mulai mengerjakan proyek ini
Bluetooth Amp + Isolasi Switch (Dua Amp Berbagi Sepasang Speaker): 14 Langkah (dengan Gambar)
Bluetooth Amp + Isolasi Switch (Dua Amp Berbagi Sepasang Speaker): Saya memiliki pemutar rekaman Rega P1. Ini dicolokkan ke sistem midi Hitachi tahun 90-an (MiniDisc, tidak kurang), yang dicolokkan ke sepasang speaker TEAC yang saya beli seharga beberapa pound dari Gumtree, karena saya merusak salah satu speaker asli pada perangkat Tec
Membuat Bookhuddle.com, Situs Web untuk Menemukan, Mengatur, dan Berbagi Informasi Buku: 10 Langkah
Membuat Bookhuddle.com, Situs Web untuk Menemukan, Mengatur, dan Berbagi Informasi Buku: Posting ini menjelaskan langkah-langkah yang terlibat dalam membuat dan meluncurkan Bookhuddle.com, sebuah situs web yang bertujuan membantu pembaca menemukan, mengatur, dan berbagi informasi buku. Langkah-langkah dijelaskan di sini akan berlaku untuk pengembangan situs web lain
Cara Berbagi Foto Anda Dari Mac Mini Anda di Internet: 6 Langkah
Cara Berbagi Foto Anda Dari Mac Mini Anda di Internet: "Picasa - batas 1 GB"Flickr - 100 MB"Photobucket - 1 GB"Mac mini Anda - Tidak Terbatas!!!***"Setiap situs berbagi foto umum lainnya di luar sana, beberapa batasan ukuran file bodoh dan ruang terbatas dan batasan tidak masuk akal lainnya. Tunggu