Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  21:37[Войти] | [Зарегистрироваться]
Ответ на вопрос № 14809

11-12-2002 13:09
Что использовать для отображения картинок в Делфи, которые были сохранены
в БД ms Access как поле объекта OLE.
При использовании dbImage возникает ошибка.
И как в mdb можно хранить картинки.

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

22-04-2003 10:41
Есть такой компонент TDBOLEContainer ...

21-04-2003 03:50
Смещение 82 байта бывает тогда, когда картинки засовывались в руссифицированной Винде. Если есть возможность, что картинки в базу будут добавляться в разных Виндах, то надо сначала это проверять.
Типа так:

Dump:Array[0..12] of Char;

BlbStr:=TBlobStream(dtmData.adtViewSchemes.CreateBlobStream(dtmData.adtViewSchemes.FieldByName('Рисунок'), bmRead));
BlbStr.Seek($14,soFromBeginning);
BlbStr.Read(Dump,12);
sDump:=StrPas(Dump);
If sDump='Bitmap Image' then
  BlbStr.Seek(78,soFromBeginning)
Else
  BlbStr.Seek(82,soFromBeginning);


21-04-2003 03:47
82 байта потому, что у тебя картинки засовывались в базу в русской Windows. В английской это смещение составляет 78 байт. Поэтому сначала проверяй, что записанно в первых байтах. Типа так:
BlbStr:=TBlobStream(dtmData.adtViewSchemes.CreateBlobStream(dtmData.adtViewSchemes.FieldByName('Рисунок'), bmRead));
BlbStr.Seek($14,soFromBeginning);
BlbStr.Read(Dump,12);
sDump:=StrPas(Dump);
If sDump='Bitmap Image' then
  BlbStr.Seek(78,soFromBeginning)
Else
  BlbStr.Seek(82,soFromBeginning);


25-02-2003 08:34
Большое спасибо. Такой способ работает, правда если смещение составляет 82 байта. Тогда еще один вопрос: как программно добавлять картинки? :)

21-02-2003 12:43
Знакомая проблема...
Она заключается в том, что BLOB-поля  хранятся не в исходном виде, а как OLE-объекты с заголовками памяти OLE в начале реальных графических данных. Этот заголовок составляет 78 байтов. Чтобы при использовании объектов TBitmap не получать сообщения "Bitmap Image is not valid", можно поступить следующим образом:

var
  bitmap:TBitmap;
  bs:TADOBlobStream;
begin
  try
    bs:=TADOBlobStream.Create(ADOTable1photo,bmRead);
    bs.Seek(78,soFromBeginning);
    bitmap:=TBitmap.Create;
    bitmap.LoadFromStream(bs);
    DBImage1.Picture.Graphic:=bitmap;
  finally
    bitmap.Free;
    bs.Free;
  end;
end;

Данный код необходимо поместить в обработчик события AfterScroll компонента, используемого для доступа к графической информации в таблице.

15-12-2002 10:08 | Сообщение от автора вопроса
Спасибо за ответ.
А можно ли просматривать image, не используя BDE,
например через ADO ?

13-12-2002 10:24
когда сидишь в access и добавляешь картинку он
показывает, что тут наличие ole объекта.

image канает для BDE.

такие вопросы уже возникали, просто поищи.
сам еще не интересовался.

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Какой месяц идет после марта?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования