Solved

Memo field in DBGrid or StringGrid?

Posted on 1998-09-15
5
1,488 Views
Last Modified: 2010-05-18
Hi,

I need to put a memo of some kind in a grid so that you can edit the memo field in the grid (Delphi 4).  I know that components like InfoPower are the best way to do this but is there another way?

Thank you,
/MP
0
Comment
Question by:mikepj
5 Comments
 
LVL 1

Expert Comment

by:Greedy
ID: 1339755
When you say memo in a grid what do you want?
1) when the user enters the field a membo box pops up and then goes away on field's loss on focus

2) for the user to be able to type and view memo data from the grid.  If this is what you want do you want the boxes of the other fields to expand with the memo field's box or do you want the memo filed to wrap around the record or something like that?
0
 
LVL 10

Expert Comment

by:viktornet
ID: 1339756
Here is what you do:-)

In the OnDrawCell() of the string grid....
---------
procedure TForm1.SGDrawCell(Sender: TObject; Col, Row: Integer;
  Rect: TRect; State: TGridDrawState);
begin
     if(col = 1)and(row = 1) then
     with Memo1 do
     begin
          Parent := SG;
          Left := Rect.Left;
          Top := Rect.Top;
          Width := Rect.Right div 2;
          Height := Rect.Bottom div 2;
     end;
end;
-----------
Regards,
Viktor Ivanov
0
 
LVL 2

Author Comment

by:mikepj
ID: 1339757
Thank you for your reply,

Although on the surface, this answer does work, there are a number of problems which come up when I do this.  Things like:

- problems with focus control
- making it clear to the user what's happening
- dealing with times when it is not the top row item that is being edited

I am hoping to have a component that does this in a nice way rather than something that is kind of a mess.

/MP

0
 

Accepted Solution

by:
huizhang earned 100 total points
ID: 1339758
mikepj

It is very simple to display or edit a memo field in TDBGrid.

In design mode do following;
1. doulble click on your table icon, add your fields(include the
   memo field (here is called 'MemoField')
2. hilight the memo field
3. in the Object Inspector, add two events for the memo field
   OnGetText and OnSetText, coded as:

procedure TForm1.Table1MemoFieldGetText(Sender: TField; var Text: String;
  DisplayText: Boolean);
begin
  Text:=Table1MemoField.AsString;
end;

procedure TForm1.Table1MemoFieldSetText(Sender: TField; const Text: String);
begin
  Table1MemoField.AsString:=Text;
end;

0
 
LVL 2

Author Comment

by:mikepj
ID: 1339759
Thank you for your answer.  This doesn't solve my main problem per se but did provide a useful bit of information.  I ended up doing a bit of a crazy solution to the problem using a memo which becomes visible superimposed over the grid when the memo field is entered.
0

Featured Post

What is SQL Server and how does it work?

The purpose of this paper is to provide you background on SQL Server. It’s your self-study guide for learning fundamentals. It includes both the history of SQL and its technical basics. Concepts and definitions will form the solid foundation of your future DBA expertise.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Introduction The parallel port is a very commonly known port, it was widely used to connect a printer to the PC, if you look at the back of your computer, for those who don't have newer computers, there will be a port with 25 pins and a small print…
Introduction Raise your hands if you were as upset with FireMonkey as I was when I discovered that there was no TListview.  I use TListView in almost all of my applications I've written, and I was not going to compromise by resorting to TStringGrid…
Nobody understands Phishing better than an anti-spam company. That’s why we are providing Phishing Awareness Training to our customers. According to a report by Verizon, only 3% of targeted users report malicious emails to management. With compan…
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…

810 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question