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: 07:05:45 11/15/01 Thu
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:46:50 11/14/01 Wed

Michel,
I've already done this change but i get the "invalid BLOB lenght" error in tquery.Post
Any idea?


>
>Hi Ruy,
>
>I missed that on my last post:
>
>var Field : TBlobStream ;
>
>Field is TBlobStream not a TBlobField in your code. I
>made the mistake in my original example. It should be,
>
>var Field : TBlobField;
>
>I'm sorry about that.
>
>Best regards,
>
>Michel
>
>>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 ]

[ 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.