powered by simpleCommunicator - 2.0.59     © 2025 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Программирование [игнор отключен] [закрыт для гостей] / Хранение приложением большого числа картинок малого размера на разных ОС
25 сообщений из 48, страница 1 из 2
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644696
Фотография mraklbrw
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Добрый день.
Столкнулся с такой проблемой - разрабатывается кросплатформенное приложение (Windows, Android, возможно,IOS).
Приложение должно хранить большое количество (>10-30k) картинок размером 10-200 Кб.
При использовании пользователем часто будет осуществляться открытие какого-либо файла.
Однако, сами файлы почти никогда изменяться не будут.
Суть в том, что, по опыту сталкивался с таким количеством файлов на Windows и знаю, что могут быть тормоза.
+ удаление, распаковка приложения, перемещение информации с карты памяти на память телефона и обратно по желанию пользователя - будут долгими.
Вопрос в том - как хранить - в Sqlite?
Есть ещё бредовая идея - самому написать формат хранения и хранить как несколько больших файлов.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644705
miksoft
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
в zip-архиве.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644706
Фотография Изопропил
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
miksoftв zip-архиве.
Сжатые картинки??
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644707
Фотография mraklbrw
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
miksoft,

Каждый раз при запуске программы распаковывать - плохой вариант.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644710
miksoft
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Изопропилmiksoftв zip-архиве.
Сжатые картинки??Зато один файл.
Можно было бы tar предложить, но zip более распространен во всяких библиотеках.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644712
miksoft
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
mraklbrwКаждый раз при запуске программы распаковывать - плохой вариант.Не при запуске, а перед показом. И не в файл, а в память. Чтобы ускорить распаковку можно даже режим сжатия поставить на "без сжатия".
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644732
вадя
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
mraklbrw,
тормоза возникают когда такое количество файлов находятся в одной папке . из практики - в папке не должно быть более 1,5к файлов
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644736
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
mraklbrwСтолкнулся с такой проблемой - разрабатывается кросплатформенное приложение (Windows, Android, возможно,IOS).

Проблема-то в чём выражается? Фалойвая система это база данных для хранения файлов, лучше ещё ничего не придумали в отношении эффективного хранения.

Храните файлы в папках по 500-1000 файлов в одной папке. Всё.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644739
Фотография tchingiz
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
вадяmraklbrw,
тормоза возникают когда такое количество файлов находятся в одной папке . из практики - в папке не должно быть более 1,5к файлов
+1
в файловой системе плохо -- придется извращаться с искусственно городимым разделением
файлов по бинарному в моей истории - по двухуровневому (26+10) * (26+10) арному дереву (буквы латинского алфавита + цифры).
Причем файлу приписывали хешкод - в зависимости от которого рассовывали файлы по дереву.
по первым двум символам хешкода брали первый каталог, по вторым - второй.
Этого хватило, контора развалилась до вырождения системы.



Описание файла и хешкода лежало в сайбейз ану для поиска.

Проще сразу взять SQLite
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644740
Фотография tchingiz
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
miksoftв zip-архиве.
через год работы окажется что 90% картинок - уже упакованные jpg
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644742
miksoft
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
tchingizmiksoftв zip-архиве.
через год работы окажется что 90% картинок - уже упакованные jpgДа и пожалуйста. Хоть все 100%. Суть не в сжатии, суть в одном файле и контейнере, с которым несложно работать.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644744
schi
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Lightroom хранит превью-картинки в иерархии каталогов. И не тормозит показе части из сотен тысяч изборажений.
Проверено электроникой.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644751
Фотография tchingiz
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
miksofttchingizпропущено...

через год работы окажется что 90% картинок - уже упакованные jpgДа и пожалуйста. Хоть все 100%. Суть не в сжатии, суть в одном файле и контейнере, с которым несложно работать.
работа на сжатие же будет тратиться?
или можно без сжатия сохранять?
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644752
Фотография tchingiz
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
в файловой системе - заметная деградация скорости доступа - налицо,
zip архив тоже нужно было бы протестировать на большое число картинок и большое число вставок удалений в/из архива
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644753
Dima T
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
tchingizработа на сжатие же будет тратиться?
или можно без сжатия сохранять?
Многие архиваторы позволяют задавать степень сжатия, и один из вариантов "без сжатия", т.е. просто вставляют файл в архив без изменений.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644755
Фотография Akina
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Вариант с архивом картинок без сжатия почти эквивалентен варианту выделенного тома под хранение этих картинок. Причём хранения в одном каталоге. Всей разницы - запросы от приложения обрабатывает не файловый реквестор, а библиотека сжатия/разжатия. Когда количество перевалит за десяток тысяч, то тормоза начнутся того же порядка, что и при хранении в файловой системе, и даже по почти той же самой почти причине - невозможности кэшировать на уровне приложения местоположение отдельного файла, минуя файловый реквестор или библиотеку (де)компрессии. На кэш ОС надежды мало. Держать файл постоянно открытым через библиотеку декомпрессии, чтобы она не сбрасывала каталог архива?

Я бы скорее предложил подумать о потоковом хранении метафайлов в файле-библиотеке - это позволит на старте одни раз прочитать и закэшить в приложении местоположение отдельных метафайлов в большом файле библиотеки изображений и считывать их, когда потребуются, сразу по известным смещению и размеру.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644757
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Можно в одну большую картинку запихнуть все. В играх так делают.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644763
Фотография Изопропил
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
maytonМожно в одну большую картинку запихнуть все. В играх так делают.
А вот это и будет извращение
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644765
Фотография tchingiz
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Dima Ttchingizработа на сжатие же будет тратиться?
или можно без сжатия сохранять?
Многие архиваторы позволяют задавать степень сжатия, и один из вариантов "без сжатия", т.е. просто вставляют файл в архив без изменений.
ок.
а если картинок много, то, конечно, не придется выискивать какие то из них, при
помощи разных описаний картники (я на селект фром вере намекаю) и
не нужно искать потерянные-отсутствующие картинки (которые появятся в результате ошибок
в приложении)?
и утилитой zip.exe пользоваться удобнее, чем утилитой sqlite3.exe?
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644771
ВМоисеев
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
>mraklbrw, вчера, 23:28 http://www.sql.ru/forum/actualutils.aspx?action=gotomsg&tid=1293129&msg=21409526] [21409526]

>...Вопрос в том - как хранить …
А если так:
1. все картинки в одном(?) бинарном файле,
2. Идентификатор, начало, длина в Sqlite
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644776
Соколинский Борис
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
mraklbrw+ удаление, распаковка приложения, перемещение информации с карты памяти на память телефона и обратно по желанию пользователя - будут долгими.

С другой стороны, хранение картинок в СУБД имеет существенный недостаток - невозможно пользоваться готовыми утилитами для их обработки и на каждый чих писать какой-то код.
ИМХО, все перечисленное - не настолько частые операции чтобы под них подстраиваться.
Сложнее аккуратно сделать откаты транзакций, но если такой проблемы нет - я бы оставил файловое хранение.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644777
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ИзопропилmaytonМожно в одну большую картинку запихнуть все. В играх так делают.
А вот это и будет извращение
Для иконок нормально. Тем более если они никак не меняются на протяжении сессии пользователя.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644779
Фотография Изопропил
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
mayton,

IMHO не иконки у топикстартера
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644803
schi
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Вот так, с помощью нехитрых приспособлений буханку белого (или черного) хлеба можно превратить в троллейбус… Но зачем?

Программы обработки изображений сталкиваются с проблемой, поднятой ТС, по 10 раз на дню и как-то их обходят. Не проще посмотреть, как, благо исходников открытых хватает.
...
Рейтинг: 0 / 0
Хранение приложением большого числа картинок малого размера на разных ОС
    #39644830
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
На хабре есть хорошая статья про кеширование картинок. Думаю автору это будет полезно.

По поводу Windows приложения и андроид.
Их нельзя писать в строчку через запятую.
Windows легко прогрузит 300 мб картинок.
А с Андроидом нужен некий эконом режим.
Вобщем это вопрос в топик мобильной
Разоаботки.
...
Рейтинг: 0 / 0
25 сообщений из 48, страница 1 из 2
Форумы / Программирование [игнор отключен] [закрыт для гостей] / Хранение приложением большого числа картинок малого размера на разных ОС
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]