Модераторы: Poseidon, Snowy, bems, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Особенности TdbGrid, Ширина столбцов в tDBGrid 
:(
    Опции темы
DenisTv
Дата 8.4.2011, 10:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 64
Регистрация: 3.11.2005

Репутация: нет
Всего: нет



Доброго времени суток!

Реализую алгоритм сохранения размера столбцов tDBGrid в файл(ini).
Сохраняю значения table.Fields[i].FieldName и table.Fields[i].DisplayWidth.

При восстановлении возвращаю эти значения соответствующим таблицам. И всё было хорошо, пока я не передвинул ползунок ширины столбца мышкой. Таблица отказалась восстанавливать размеры, т.к. значения помещаю в  table.Fields[i].DisplayWidth, а мышкой изменил dbGrid.Column[i].Width.

Как я понимаю есть три способа передать сетке длину столбца:
1. table.Fields[i].DisplayWidth;
2. dbGrid.Fields[i].DisplayWidth;
3. dbGrid.Column[i].WIdth;

Вопросы:
1. В чем отличие этих способов передачи?
2. Почему значение Column всегда больше Fields?
3. Кто как реализовывал подобное? (может не там копаю  smile )
PM MAIL ICQ   Вверх
Frees
Дата 8.4.2011, 10:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2233
Регистрация: 2.12.2005
Где: Екатеринбург

Репутация: 9
Всего: 54



Цитата(DenisTv @  8.4.2011,  13:39 Найти цитируемый пост)
Реализую алгоритм сохранения размера столбцов tDBGrid в файл(ini).

дак и сохраняй
dbGrid.Column[i].Width для dbGrid.Column[i].FieldName 
а не 
Цитата(DenisTv @  8.4.2011,  13:39 Найти цитируемый пост)
table.Fields[i].FieldName и table.Fields[i].DisplayWidth.


Добавлено через 4 минуты и 52 секунды
Цитата(DenisTv @  8.4.2011,  13:39 Найти цитируемый пост)
1. table.Fields[i].DisplayWidth;2. dbGrid.Fields[i].DisplayWidth;

это одно и тоже сслка на поле только из разных мест
это ширина в символах




Цитата(DenisTv @  8.4.2011,  13:39 Найти цитируемый пост)
dbGrid.Column[i].WIdth;

текущая ширина колонки, в пикселях

Это сообщение отредактировал(а) Frees - 8.4.2011, 10:43


--------------------
Кольцов Виктор Владимирович
PM MAIL ICQ   Вверх
Данкинг
Дата 8.4.2011, 10:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: 9
Всего: 130



Цитата(DenisTv @  8.4.2011,  11:39 Найти цитируемый пост)
 Кто как реализовывал подобное?

Вот так и реализовывал, сохраняя ширину в реестр:
Цитата(DenisTv @  8.4.2011,  11:39 Найти цитируемый пост)
dbGrid.Column[i].WIdth




--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
DenisTv
Дата 13.4.2011, 13:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 64
Регистрация: 3.11.2005

Репутация: нет
Всего: нет



Спасибо. Сделал.

Еще вопрос на засыпку: как сделать авторазмер столбцов dbGrid? Чтобы они пропорционально занимали всю область dbGrid-а. 
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Общие вопросы"
SnowyMetalFan
bemsPoseidon
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0886 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.