Оглавление:
2025 Автор: John Day | [email protected]. Последнее изменение: 2025-01-23 15:05
В этом руководстве мы создадим приложение для iOS со Swift, которое позволит вам обмениваться фотографиями с кем угодно, находящимся поблизости, без необходимости сопряжения устройств.
Мы будем использовать Chirp Connect для отправки данных с использованием звука и Firebase для хранения изображений в облаке.
Отправка данных со звуком создает уникальный опыт, когда данные могут быть переданы любому человеку в пределах слышимости.
Шаг 1. Установите требования
Xcode
Установить из App Store.
Какао-стручки
sudo gem установить cocoapods
Chirp Connect iOS SDK
Зарегистрируйтесь на admin.chirp.io
Шаг 2: настройка проекта
1. Создайте проект Xcode.
2. Войдите в Firebase и создайте новый проект.
Включите Firestore, щелкнув раздел «База данных» и выбрав Cloud Firestore. Щелкните «Функции», чтобы также включить облачные функции.
3. Выполните настройку приложения для iOS на странице обзора проекта.
Вам понадобится идентификатор пакета из вкладки «Общие» в настройках проекта Xcode. После создания подфайла вам нужно будет добавить следующие зависимости перед запуском установки модуля.
# Подов для проекта
pod 'Firebase / Core' pod 'Firebase / Firestore' pod 'Firebase / Storage'
4. Загрузите последнюю версию Chirp Connect iOS SDK с сайта admin.chirp.io/downloads.
5. Следуйте инструкциям на сайте developers.chirp.io, чтобы интегрировать Chirp Connect в Xcode.
Перейдите в Начало работы / iOS. Затем прокрутите вниз и следуйте инструкциям по настройке Swift. Это будет включать в себя импорт фреймворка и создание связующего заголовка.
Теперь настройка завершена, можно приступить к написанию кода! Рекомендуется проверять сборки вашего проекта на каждом этапе установки.
Шаг 3. Напишите код IOS
1. Импортируйте Firebase в свой ViewController и расширьте NSData, чтобы включить расширение hexString, чтобы мы могли преобразовать полезные данные Chirp Connect в шестнадцатеричную строку. (Chirp Connect будет доступен по всему миру благодаря мостовому заголовку).
импортировать UIKit
импортировать Firebase
extension Data {
var hexString: String {return map {String (format: "% 02x", UInt8 ($ 0))}.joined ()}}
2. Добавьте делегатов ImagePicker в свой ViewController и объявите переменную ChirpConnect с именем connect.
class ViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate {
var connect: ChirpConnect? переопределить функцию viewDidLoad () {super.viewDidLoad ()…
3. После super.viewDidLoad инициализируйте Chirp Connect и настройте полученный обратный вызов. В полученном обратном вызове мы получим изображение из Firebase, используя полученную полезную нагрузку, и обновим ImageView. Вы можете получить свои APP_KEY и APP_SECRET из admin.chirp.io.
connect = ChirpConnect (appKey: APP_KEY иSecret: APP_SECRET), если let connect = connect {connect.getLicenceString {(license: String ?, error: Error?) в if error == nil {if let license = license {connect.setLicenceString (лицензия) connect.start () connect.receivedBlock = {(data: Data?) -> () in if let data = data {print (String (format: "Полученные данные:% @", data.hexString)) let file = Storage.storage (). Reference (). Child (data.hexString) file.getData (maxSize: 1 * 1024 * 2048) {imageData, ошибка в if let error = error {print ("Error:% @", error.localizedDescription)} else {self.imageView.image = UIImage (data: imageData!)}}} else {print ("Ошибка декодирования"); }}}}
4. Теперь добавьте код для отправки данных изображения после его выбора в пользовательском интерфейсе.
func imagePickerController (_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String: Any])
{let imageData = info [UIImagePickerControllerOriginalImage] как? UIImage let data: Data = UIImageJPEGRepresentation (imageData !, 0.1)! self.imageView.image = imageData let metadata = StorageMetadata () metadata.contentType = "image / jpeg" if let connect = connect {let key: Data = connect.randomPayload (withLength: 8) Firestore.firestore (). collection (" uploads "). addDocument (data: [" key ": key.hexString," timestamp ": FieldValue.serverTimestamp ()]) {ошибка в 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 (анимированный: true, завершение: nil)}
Примечание. Вам нужно будет добавить в свой Info.plist параметры Конфиденциальность - Описание использования библиотеки фотографий, Конфиденциальность - Описание использования библиотеки фотографий и Конфиденциальность - Описание использования микрофона, чтобы предоставить разрешения на использование камеры, библиотеки фотографий и микрофона.
Шаг 4: Создайте пользовательский интерфейс
Теперь перейдите в файл Main.storyboard, чтобы создать пользовательский интерфейс.
1. Перетащите ImageView и две кнопки на раскадровку с панели «Библиотека объектов» в правом нижнем углу.
2. Для каждой кнопки добавьте ограничение по высоте около 75 пикселей, выбрав компонент и нажав кнопку «Добавить новые ограничения» (та, которая выглядит как истребитель «Звездных войн»), а затем введите высоту и нажмите Enter.
3. Выберите все три компонента и поместите их в стек, нажав кнопку «Вставить в стек».
4. Теперь откройте редактор помощника, нажмите CTRL и перетащите от каждого компонента к коду ViewController, чтобы создать выходы для каждого компонента.
@IBOutlet var imageView: UIImageView!
@IBOutlet var openLibraryButton: UIButton! @IBOutlet var openCameraButton: UIButton!
5. Теперь CTRL и перетащите от обеих кнопок, чтобы создать действие для открытия пользовательского интерфейса камеры / библиотеки.
6. В действии «Открыть библиотеку» добавьте следующий код.
@IBAction func openLibrary (_ отправитель: Любой) {
пусть imagePicker = UIImagePickerController () imagePicker.delegate = self; imagePicker.sourceType =.photoLibrary self.present (imagePicker, animated: true, завершения: nil)}
7. В действии "Открыть камеру"
@IBAction func openCamera (_ отправитель: Любой) {
пусть imagePicker = UIImagePickerController () imagePicker.delegate = self imagePicker.sourceType =.camera; self.present (imagePicker, animated: true, Завершение: nil)}
Шаг 5: напишите облачную функцию
Поскольку фотографии не обязательно хранить в облаке вечно, мы можем написать облачную функцию для выполнения очистки. Это может запускаться как функция HTTP каждый час службой cron, такой как cron-job.org.
Прежде всего нам нужно установить firebase-tools
npm install -g firebase-tools
Затем из корневого каталога проекта запустите
firebase init
Выберите функции из командной строки для инициализации облачных функций. Вы также можете включить firestore, если хотите настроить Firestore.
Затем откройте functions / index.js и добавьте следующий код. Не забудьте изменить
к вашему идентификатору проекта Firebase.
const functions = require ('firebase-functions');
const admin = require ('firebase-admin'); admin.initializeApp () exports.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 ()}) вернуть response.status (200).send ('OK')}).catch (err => response.status (500).send (err))});
Развернуть облачные функции так же просто, как запустить эту команду.
firebase развернуть
Затем на cron-job.org создайте задание, которое будет запускать эту конечную точку каждый час. Конечная точка будет чем-то вроде
us-central1-project_id.cloudfunctions.net/cleanup
Шаг 6. Запустите приложение
Запустите приложение на симуляторе или устройстве iOS и начните делиться фотографиями!
Рекомендуемые:
Цифровые часы со светодиодной точечной матрицей - приложение ESP Matrix для Android: 14 шагов
Цифровые часы со светодиодной точечной матрицей - приложение ESP Matrix для Android: эта статья с гордостью спонсируется PCBWAY. Компания PCBWAY создает высококачественные прототипы печатных плат для людей во всем мире. Попробуйте сами и получите 10 печатных плат всего за 5 долларов на PCBWAY с очень хорошим качеством, спасибо PCBWAY. Матричная плата ESP, которую я разработал
Приложение дистанционного управления AmbiBox IOS: 5 шагов
Приложение для дистанционного управления AmbiBox IOS: с помощью этого приложения для iOS вы можете управлять своим AmbiBox со своего iPhone или iPad. Я собираюсь поговорить о приложении и о том, как оно взаимодействует с сервером AmbiBox. Если вы хотите узнать, как установить AmbiBox и светодиодные ленты, в
Доска для рисования со светодиодной подсветкой Bluetooth и приложение для iOS: 9 шагов (с изображениями)
Доска для рисования светодиодов Bluetooth и приложение для iOS: в этом руководстве вы сможете создать плату светодиодов Bluetooth, которая может рисовать изображения из созданного нами приложения для iPhone. В этом приложении пользователи смогут создать игру Connect 4, которая также будет отображаться на этой игровой доске. Это будет ч
Приложение Android / iOS для удаленного доступа к маршрутизатору OpenWrt: 11 шагов
Приложение Android / iOS для удаленного доступа к маршрутизатору OpenWrt: недавно я купил новый маршрутизатор (Xiaomi Mi Router 3G). И, конечно же, это новое замечательное оборудование вдохновило меня начать работу над этим проектом;)
Простое приложение IOS для модулей BLE: 4 шага
Простое приложение IOS для модулей BLE: в этом руководстве рассказывается, как создать приложение iOS с очень простыми функциями. Эта инструкция не будет проходить через весь процесс создания приложения BLE для iOS. Это даст только общий обзор некоторых важных элементов без