VoyForums
[ Show ]
Support VoyForums
[ Shrink ]
VoyForums Announcement: Programming and providing support for this service has been a labor of love since 1997. We are one of the few services online who values our users' privacy, and have never sold your information. We have even fought hard to defend your privacy in legal cases; however, we've done it with almost no financial support -- paying out of pocket to continue providing the service. Due to the issues imposed on us by advertisers, we also stopped hosting most ads on the forums many years ago. We hope you appreciate our efforts.

Show your support by donating any amount. (Note: We are still technically a for-profit company, so your contribution is not tax-deductible.) PayPal Acct: Feedback:

Donate to VoyForums (PayPal):

Login ] [ Contact Forum Admin ] [ Main index ] [ Post a new message ] [ Search | Check update time | Archives: 123456[7]8910 ]


[ Next Thread | Previous Thread | Next Message | Previous Message ]

Date Posted: 14:00:51 11/14/01 Wed
Author: Ruy
Subject: Re: Invalid offset into the BLOB - AGAIN - Correction
In reply to: Michel 's message, "Re: Invalid offset into the BLOB - AGAIN - Correction" on 17:31:20 11/13/01 Tue

Hi Michel,

Yes, it is a TBlobField type in Delphi. But in the SQLServer it is a image type.

var Field : TBlobStream ;
Graphic: TTiffGraphic;
begin
qryQuery.Edit;
Stream := TMemoryStream.Create;
Graphic:=TTiffGraphic.Create;
Graphic:=ImageScrollBox.Graphic as TTiffGraphic;
Graphic.SaveToStream(Stream);
Stream.Seek(0, soFromBeginning);
Field := qryQuery.FieldByName('Image') as TBlobField;
Field.LoadFromStream(Stream);
qryQuery.Post;
Graphic.Free;
Stream.Free;
end;
When i try to run the example i get the COMPILATION error "Incompatible types TBloabStream and TBloabField" in the line Field := qryQuery.FieldByName('Image') as TBlobField;

>
>Hi Ruy,
>
>The first thing I would check is the type of your
>field.
>
>Look at FieldByName('Picture').ClassName in a variable
>with the debugger. Is it really a TBlobField?
>
>Best regards,
>
>Michel
>
>>Hi Michel,
>>
>>When i use this method i get the error "incompatible
>>type TBlobStream and TBlobField" in
>>Field := FieldByName('Picture') as TBlobField;
>>
>>>
>>>Dear Petko,
>>>
>>>I would be very suprised it is the SaveToStream
>method
>>>that is problematic; I have used this method
>thousands
>>>of times for tiff files.
>>>
>>>It must be some interaction with TBlobStream.
>>>
>>>I would recommend using a TMemoryStream instead
>>>instead of a TBlobStream:
>>>
>>>var
>>>Stream : TMemoryStream;
>>>Field : TBlobStream;
>>>
>>>...
>>>
>>>Stream := TMemoryStream.Create;
>>>Graphic.SaveToStream(Stream);
>>>Stream.Seek(0, soFromBeginning);
>>>
>>>Field := FieldByName('Picture') as TBlobField;
>>>Field.LoadFromStream(Stream);
>>>
>>>Stream.Free;
>>>
>>>Best regards,
>>>
>>>Michel
>>>
>>>>I have placed a wrong example - the first - in the
>>>>previous posted letter. That is the correct variant
>>of
>>>>the procedure.
>>>>
>>>>procedure TMain.aLoadShemaExecute(Sender: TObject);
>>>>var
>>>> Stream: TBlobStream;
>>>> Graphic: TTiffGraphic;
>>>>begin
>>>> with OpenPictureDialog1 do
>>>> if Execute then
>>>> begin
>>>> ImageShema.Picture.LoadFromFile(FileName); //
>>Only
>>>>tiff files (ImageShema: TImage)
>>>>
>>>> with DataModule1.tblTree do
>>>> begin
>>>> Edit;
>>>>
>>>>Stream:=TBlobStream.Create(FieldByName('Picture') as
>>>>TBlobField, bmWrite);
>>>> Graphic:=TTiffGraphic.Create;
>>>> Graphic:=ImageShema.Picture.Graphic as
>>>>TTiffGraphic;
>>>> Graphic.SaveToStream(Stream); // Here raise
>the
>>>>error
>>>> Post;
>>>> Graphic.Free;
>>>> Stream.Free;
>>>> end;
>>>> end;
>>>>end;

[ Next Thread | Previous Thread | Next Message | Previous Message ]


Replies:


[ Contact Forum Admin ]


Forum timezone: GMT-5
VF Version: 3.00b, ConfDB:
Before posting please read our privacy policy.
VoyForums(tm) is a Free Service from Voyager Info-Systems.
Copyright © 1998-2019 Voyager Info-Systems. All Rights Reserved.