Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3

Ширина поля StringGrid не соответствует ширине столбца в Excel

17.01.2016, 19:53. Показов 1647. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!!! Давно хотел задать этот вопрос. Скажите кто-нить заметил разницу, кто занимался хоть раз программно создавать отчёт в экселе, что ширина полей в компоненте например StringGrid и ширина полей в экселе, визуально отличается, по пикселям одинаково? Как-то это можно исправить или это проделки экселя?
Привожу 2 скриншота на котором чётко видно, что ширина поля в StringGrid визуально отличается от ширины поля в эксель, хотя имеют ширину поля по 240 пикселей
Миниатюры
Ширина поля StringGrid не соответствует ширине столбца в Excel   Ширина поля StringGrid не соответствует ширине столбца в Excel  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
17.01.2016, 19:53
Ответы с готовыми решениями:

StringGrid and FixCol / ширина первого столбца /
Кто нибудь знает, как в StringGrid сделать ширину первого (фиксированного) столбца шире всех остальных. Если изменять, то изменяется во...

Ширина столбца и закрытие Excel документа
Работаю с oracle ado/odbc. Нужно перенести данные в из дбгрид в таблицу Excel/ задачей справилась успешно, но возникли вопросы 1)...

Не меняется ширина столбца при выгрузке в Excel
При выгрузке в Excel не меняется ширина столбца, хотя код прописал верный: Worksheet.Columns.Range.ColumnWidth := 30; Высота...

5
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33377 / 21501 / 8236
Регистрация: 22.10.2011
Сообщений: 36,896
Записей в блоге: 11
17.01.2016, 20:24
Поинтересуйся в MSDN, в чем выставляется ширина столбца в Excel. Там написано, что в Point-ах. Тебе нужна формула, конвертирующая пиксели в эти самые Point-ы.
1
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
17.01.2016, 21:29  [ТС]
Цитата Сообщение от volvo Посмотреть сообщение
конвертирующая пиксели в эти самые Point-ы.
А эта формула находится в MSDN или где её можна найти?
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33377 / 21501 / 8236
Регистрация: 22.10.2011
Сообщений: 36,896
Записей в блоге: 11
18.01.2016, 01:05
Лучший ответ Сообщение было отмечено Sasha как решение

Решение

Стоп. Отбой. Там не point-ы, В пойнтах ширину возвращает метод Width, а метод ColumnWidth работает в character-ах. Приблизительная формула:
C++
1
2
3
4
double Pix2Char(int pix)
{
    return (pix - 5) / 7.0;
}
, и установка:
C++
1
ws.OlePropertyGet("Columns").OlePropertyGet("Item", 1).OlePropertySet("ColumnWidth", Pix2Char(StringGrid1->ColWidths[0]));
, для стандартного шрифта работает, при изменении шрифта тебе нужно будет опять искать формулу, в общем, там с этим полный БАРДАК, как будто специально сделано, чтобы максимально усложнить работу с этими свойствами...
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
18.01.2016, 09:55  [ТС]
volvo, а ты эту формулу сам вывел или где-то прочитал?
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33377 / 21501 / 8236
Регистрация: 22.10.2011
Сообщений: 36,896
Записей в блоге: 11
18.01.2016, 10:20
Было в обсуждениях на social.msdn.microsoft.com: Setting column width in Pixel. К сожалению, те ссылки, которые приводятся там (и по которым должно быть объяснение, как они говорят, почему именно так) - уже неактуальны, MS убила все комментарии пользователей в MSDN, где, собственно, эта информация и располагалась. Я ж говорю: вредители, сами - только усложняют, когда другие что-то хотят облегчить - это нужно уничтожить.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.01.2016, 10:20
Помогаю со студенческими работами здесь

Как ширину одного из столбцов поля со списком сделать равной ширине столбца формы?
Здравствуйте! Подскажите пожалуйста, как ширину одного из столбцов поля со списком сделать равной ширине столбца формы? У меня в...

Ширина th не соответствует td
В браузере все отображается хорошо, а на телевизоре ширина th как бы фиксированная, но самая строка в thead на всю ширину экрана. На...

Ширина блока по ширине контента
Подскажите, можно ли только корректировкой CSS решить задачу? Для демонстрации есть упрощенный код. Кнопки меню. Когда название раздела...

Ширина столбцов таблицы не соответствует значениям
Есть таблица, двадцать столбцов. Свойство для таблицы сделал следующее: table-layout:fixed;Перед тегом <tr> указал значение длины...

Ширина столбцов DataGridView по ширине данных в ячейках
Как можно сделать ширину столбцов по ширине данных, которые в их ячейках? Достаю данные из БД, есть много строк с пробелами (поле на 50...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru