Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > Delphi программирование > БД в Delphi
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 26.04.2009, 19:15   #1
Karinka
Пользователь
 
Регистрация: 31.10.2008
Сообщений: 26
Вопрос ширина столбцов!

Сделала БД в ACCESSE загружает в DBGrid все нормально, только столбцы растягиваются, как сделать столбцы определенной, заданной ширины?
Связь осуществляется через ADO
Karinka вне форума Ответить с цитированием
Старый 26.04.2009, 21:05   #2
ArtInt
Форумчанин
 
Аватар для ArtInt
 
Регистрация: 06.03.2009
Сообщений: 583
По умолчанию

1.Можно и ручную подтянуть на сетке до компиляции.
2. Щелкни по Adotable, вызови Field Editor, добавь поля и для каждого поля измени свойство DisplayWidth.
3. Таким же способом как во 2 можно и DBGrid сделать.
4. Программным кодом вставить где нибудь примерно так
Код:
DbGridDate.Fields[1].DisplayWidth:=20;
Не стыдно чего-то не знать, стыдно не стремиться к знаниям.
ArtInt вне форума Ответить с цитированием
Старый 28.04.2009, 08:21   #3
Karinka
Пользователь
 
Регистрация: 31.10.2008
Сообщений: 26
По умолчанию

Спасибо большое!!! и еще вопросик, а можно сделать чтобы в столбце выводился текст в несколько строк, а то строка длиннющая получается
Karinka вне форума Ответить с цитированием
Старый 28.04.2009, 08:48   #4
Stilet
Белик Виталий :)
Старожил
 
Аватар для Stilet
 
Регистрация: 23.07.2007
Сообщений: 57,097
По умолчанию

Цитата:
а можно сделать чтобы в столбце выводился текст в несколько строк, а то строка длиннющая получается
В стандартном DBGrid помоему такого нет.
Можно другой Грид взять с наворотами.
I'm learning to live...
Stilet вне форума Ответить с цитированием
Старый 28.04.2009, 09:15   #5
Karinka
Пользователь
 
Регистрация: 31.10.2008
Сообщений: 26
По умолчанию

а какой? а с ADO он нормально будет работать?
Karinka вне форума Ответить с цитированием
Старый 28.04.2009, 09:28   #6
Stilet
Белик Виталий :)
Старожил
 
Аватар для Stilet
 
Регистрация: 23.07.2007
Сообщений: 57,097
По умолчанию

Цитата:
а какой? а с ADO он нормально будет работать?
Смотреть надо, ну говорят вроде EhGrid из пакета EHLib неплох.
I'm learning to live...
Stilet вне форума Ответить с цитированием
Старый 28.04.2009, 11:16   #7
Karinka
Пользователь
 
Регистрация: 31.10.2008
Сообщений: 26
По умолчанию

а ты не знаешь как высоту строки увеличить?
Karinka вне форума Ответить с цитированием
Старый 28.04.2009, 11:36   #8
Stilet
Белик Виталий :)
Старожил
 
Аватар для Stilet
 
Регистрация: 23.07.2007
Сообщений: 57,097
По умолчанию

Скажу чесно - не знаю.
Но знаю другое - DBGrid для разукрашки подходит меньше всего.
Я лично пользуюсь обычным StringGrid'ом, правда заполнять его приходится "ручками" т.е. прожку писать дополнительно, но зато в нем я могу извращаться как хочу.
Есть куча других гридов с наворотами. NextGrid и EhGrid мне видеть доводилось - путевые гриды.
I'm learning to live...
Stilet вне форума Ответить с цитированием
Старый 28.04.2009, 11:37   #9
ArtInt
Форумчанин
 
Аватар для ArtInt
 
Регистрация: 06.03.2009
Сообщений: 583
По умолчанию

Попробуй так изменить высоту строк
Код:
procedure TForm1.Button1Click(Sender: TObject);
 begin
   DBGrid1.DataSource.DataSet.DisableControls;
   TStringGrid(DBGrid1).DefaultRowHeight := 55;
   DBGrid1.DataSource.DataSet.EnableControls;
 end;
Далее приводится статья Chris Hall взятая из DelphiWorld как сделать многострочный DBGrid
Многострочный DBGrid

Автор: Chris Hall
...я тоже на днях пытался сделать себе такую сеточку. Вначале я думал что можно будет ушибиться, делая такую штуку, но это оказалось совсем простым. Ничего сложного. В TDBGrid необходимо изменять высоту строки и переносить текст, если для его показа нужно более одной строки. Я не стал корежить исходники VCL, а написал своего наследника TDBGrid.

Я добавил дополнительное свойство LinesPerRow. Установка значений данного свойства соответственно изменяет высоту строки, в зависимости от текущего шрифта. Текст в ячейках будет переноситься, если значение LinesPerRow больше чем единица. Все это произведение искусств оказалось чрезвычайно полезным и удивительно простым, так что я публикую его здесь в надежде, что оно пригодится кому-нибудь еще. Код простой, но для его понимания необходимо изучение исходного кода VCL.

Я протестировал данный код и он отлично работал. Небольшая доводка все-же нужна (обработка blob-полей, обработка ошибок и пр.), но это не сложно.



Код:
unit Dbmygrid;

interface

uses

  SysUtils, WinTypes, WinProcs, Messages, Classes, Graphics, Controls,
  Forms, Dialogs, DB, DBTables, StdCtrls, ExtCtrls, Grids, DBGrids;

type

  TMultiLineDBGrid = class(TDBGrid)
  private
    FLinesPerRow: Integer;
    procedure DrawDataCell(Sender: TObject; const Rect: TRect; Field: TField;
      State: TGridDrawState);
    procedure LayoutChanged; override;
    procedure SetLinesPerRow(ALinesPerRow: Integer);
  public
    property LinesPerRow: Integer read FLinesPerRow write SetLinesPerRow default
      1;
    constructor Create(AOwner: TComponent); override;
  end;

implementation

constructor TMultiLineDBGrid.Create(AOwner: TComponent);
begin

  inherited Create(AOwner);
  FLinesPerRow := 1;
  OnDrawDataCell := DrawDataCell;
end;

procedure TMultiLineDBGrid.LayOutChanged;
begin

  inherited LayOutChanged;
  DefaultRowHeight := DefaultRowHeight * LinesPerRow;
end;

procedure TMultiLineDBGrid.DrawDataCell(Sender: TObject; const Rect: TRect;
  Field: TField; State: TGridDrawState);
var

  Format: Word;
  C: array[0..255] of Char;
begin

  if LinesPerRow = 1 then
    Format := DT_SINGLELINE or DT_LEFT
  else
    Format := DT_LEFT or DT_WORDBREAK;

  Canvas.FillRect(Rect);

  StrPCopy(C, Field.AsString);
  WinProcs.DrawText(Canvas.Handle, C, StrLen(C), Rect, Format);
end;

procedure TMultiLineDBGrid.SetLinesPerRow(ALinesPerRow: Integer);
begin

  if ALinesPerRow <> FLinesPerRow then
  begin
    FLinesPerRow := ALinesPerRow;
    LayoutChanged;
  end;
end;

end.
Не стыдно чего-то не знать, стыдно не стремиться к знаниям.
ArtInt вне форума Ответить с цитированием
Старый 28.04.2009, 12:00   #10
SERG1980
Участник клуба
 
Аватар для SERG1980
 
Регистрация: 28.03.2007
Сообщений: 1,814
По умолчанию

Цитата:
Сообщение от Stilet Посмотреть сообщение
Скажу чесно - не знаю.
Но знаю другое - DBGrid для разукрашки подходит меньше всего.
Я лично пользуюсь обычным StringGrid'ом, правда заполнять его приходится "ручками" т.е. прожку писать дополнительно, но зато в нем я могу извращаться как хочу.
Есть куча других гридов с наворотами. NextGrid и EhGrid мне видеть доводилось - путевые гриды.
RXDBGrid хорош для разукрашки
SERG1980 вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Дан двухмерный массив из 20 столбцов. Вставить в него столбец из чисел 10 после всех четных столбцов. Дмитрий142 Помощь студентам 9 07.06.2012 19:32
DBGrid ширина колонки Pinya БД в Delphi 7 07.08.2008 09:22
Динамическая ширина столбцов Nemon Общие вопросы Delphi 7 12.09.2007 13:15
Ширина столбцов в DBGrid Elena БД в Delphi 1 27.04.2007 15:34
Ширина выпадающего списка Python Microsoft Office Excel 8 11.03.2007 06:31