Nano Hash - криптовалюты, майнинг, программирование

Как сохранить изображение в SQLite в Xamarin Android?

Приложение Xamarin для Android для хранения изображения в SQLite из галереи (доступные изображения в телефоне). Мой вопрос: как хранить изображения в SQLite? И получить изображение из SQLite? Возможно ли только сжатие изображений с использованием функции растрового изображения?


  • проверьте это: stackoverflow.com/ вопросов/9357668/ и попробуйте написать аналогичный код на C# 10.08.2016
  • Проверьте ответ ниже. Я обновил ответ кодом С#. 10.08.2016

Ответы:


1

Основная идея хранения/выборки растровых изображений изображений в большинстве БД заключается в следующем:

Сохранить: преобразовать растровое изображение в Base64String и сохранить его в SQLite.

public static string Base64Encode(string plainText) {
  var plainTextBytes = System.Text.Encoding.UTF8.GetBytes(plainText);
  return System.Convert.ToBase64String(plainTextBytes);
}

Получить: получить Base64String и снова преобразовать его в растровое изображение.

public static string Base64Decode(string base64EncodedData) {
  var base64EncodedBytes = System.Convert.FromBase64String(base64EncodedData);
  return System.Text.Encoding.UTF8.GetString(base64EncodedBytes);
}
10.08.2016
  • возможен ли путь к файлу изображения в SQLite? File imgFile = new File("/storage/emulated/0/Pictures/CameraAppDemo/myPhoto_2eb3b135-5ad5-4a17-8836-13a9eca6bbb2.jpg"); Bitmap myBitmap = BitmapFactory.DecodeFile(imgFile.AbsolutePath); 25.08.2016
  • Это обычная практика в серверных технологиях. Насколько это возможно для андроида. Одна вещь, однако, если пользователь удалит фотографию вручную, путь станет недействительным. Итак, вы должны добавить еще один уровень проверки. 26.08.2016

  • 2

    Вы можете сохранить свое растровое изображение как byte[] в SQlite. Для этой операции вы должны преобразовать растровое изображение в массив байтов. Этот фрагмент кода конвертирует растровое изображение в байт[]

    var memoryStream = new MemoryStream();
    bitmap.Compress(Bitmap.CompressFormat.Png, 0, memoryStream);
    imageByteArray = memoryStream.ToArray();
    
    12.08.2016

    3
  • Ответы только на код не годятся. Пожалуйста, добавьте некоторые пояснения к вашему ответу. 30.10.2018
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..