How to determine if there is text in a TBlobField

General TRichView support forum. Please post your questions here
Post Reply
Tavo
Posts: 175
Joined: Sat Sep 24, 2005 9:25 pm
Location: Buenos Aires, Argentina
Contact:

How to determine if there is text in a TBlobField

Post by Tavo »

Hi All

I have a calculated Boolean field that it indicates to me if there is (or not) text in a field. The objective of this field is to show (in a TDBGrid) if there is text or no.

Then, if I calculate the result based on the IsNull property I do not obtain the correct result, since the field is edited by a form that contains a TDBRichViewEdit.

I need to show whether are a text in the record. Since the records are edited by a Form with a TDBRichViewEdit and other controls, although I do not even put information in the TDBRichViewEdit control, it's stores some information in the BlobField ¿right?

The property BlobSize is 0 (when IsnUll is True), but after the first "edition" no longer it returns to be 0, but an arbitrary value... depending -among other things- of the value of the RVFOptions property.

I would need something like...

CalculatedThereIsText.AsBoolean := (GetAllText(BlobField)<>'')


but, the GetAllText() function is:

function GetAllText(rv: TCustomRichView): String;
var i: Integer;
begin
if rv.ItemCount=0 then begin
Result := '';
exit;
end;
i := 0;
Result := GetItemText(rv, i);
for i := i+1 to rv.ItemCount-1 do begin
if rv.IsFromNewLine(i) then
Result := Result + #13#10;
Result := Result+GetItemText(rv, i);
end;
end;

There is some way to do this without constructing the TDBRichViewEdit control?

Thanks for readme and sorry for my english.
Tavo.
Sergey Tkachenko
Site Admin
Posts: 17646
Joined: Sat Aug 27, 2005 10:28 am
Contact:

Post by Sergey Tkachenko »

Yes, even if the document is empty, RVF may contain information about background, margins, styles (depending on RVF option), or at least RVF header line.

It's possible to parse RVF file without TRichView, but I still recommend to use TRichView to load the document and then analyze its content.
GetAllText is not a good choice because of two reasons:
1) If the document contain one picture or table or other non-text item, this function may return ''
2) It is slow: it enumerates all items, and SomeString := SomeString + AnotherString is a very slow operation if performed many times in cycle with lage string.

Use this code:
IsEmpty := (rv.ItemCount=0) or ((rv.ItemCount=1) and (rv.GetItemStyle(0)>=0) and (rv.GetItemText(0)=''))

And it's better not to use TDBRichView or TDBRichViewEdit linked to this field for this operation. It's because they format the loaded document, and formatting is the slowest operation.
Use TRichView and this procedure:

Code: Select all

function LoadRVFFromField(rv: TCustomRichView; tbl: TTable;
                          const FieldName: String): Boolean;
var Stream: TStream;
begin
  Stream := tbl.CreateBlobStream(tbl.FieldByName(FieldName), bmRead);
  try
    Result := rv.LoadRVFFromStream(Stream);
  finally
    Stream.Free;
  end;
end;
Tavo
Posts: 175
Joined: Sat Sep 24, 2005 9:25 pm
Location: Buenos Aires, Argentina
Contact:

Thanks.

Post by Tavo »

I followed your instructions and everything works very well. I use a TRichView without parent that I construct -and destroy- parallelly to the TDBGrid.
Very many thanks.
Post Reply