|
Рисование из потока |
|
|
|
Nov 11 2008, 14:18
|
Участник

Группа: Участник
Сообщений: 15
Регистрация: 11-11-08
Пользователь №: 41 540

|
Есть устройство, обменивающееся с компьютером по UART. Протокол вида: компьютер запросил - прибор померил и отдал результат. Для компьютера написана программа на Дельфи. Там в потоке принимается результат, и по факту приема выводится на экран в виде графика с помощью компонента TChart. Программа иногда зависает, иногда бывают аксес виалейшен.
Я хочу переписать программу на С, компилятор возьму MSVS C++. Как следует организовывать работу с графикой и ком-портом? Мне видится, что нужно по событию от таймера проверять состояние флага приема информации, и тогда принимающий поток будет передавать точки графика тому, кто будет рисовать на форме... Как я понял, программа часто зависала из-за того, что графика была "тяжелой", и пока что-то рисовалось в поток успевало придти несколько значений и данные терялись... Возможно, там дело обстояло несколько иначе, но мне кажется, что рисовать прямо из потока не очень хорошо. Интересно было бы увидеть как поступают другие в подобных случаях. И еще вопрос по графике. Есть ли что-то типа TChart в C++, уж очень там удобное масштабирование. Читал, что рисование в DC медленное, но может кто-то пробовал его? По сути мне нужно несколько кривых выводить, правда шкала времени (ось Х) довольно длинная, около суток и более, т.е. ничего хитрого. Но с DC придется отказаться от удобностей типа масштабирования.
|
|
|
|
|
 |
Ответов
|
Nov 18 2008, 10:32
|
Участник

Группа: Участник
Сообщений: 15
Регистрация: 11-11-08
Пользователь №: 41 540

|
Цитата(AHTOXA @ Nov 18 2008, 13:46)  Ну а я как написал? Скорее всего, это адресовалось мне. Я сейчас сделал еще один тестовый вариант с использованием компоненты TComPort. Там нечто подобное внутри реализовано - крутится поток и при приеме данных возникает событие, данные сохраняются в буфере. Так вот из этого события я уже и рисую, и пока ошибок доступа и проблем с графикой не наблюдаю. Т.к. следующее предположение верно Цитата Да и блоки скорее всего фиксированной длины. , то можно ведь изменить пункт Цитата # Распределяем память под принятое количество байтов и копируем туда принятое; на "один раз выделили в начале и потом просто пользуемся этим указателем до конца работы". Попутно вопрос: сейчас данные приходят через фиксированные промежутки времени, данные успевают обработаться за это время, и поэтому, как я понимаю, хватает одной ячейки во втором буфере. А теперь представим ситуацию, когда данные приходят нерегулярно. Тут уже потребуется FIFO с достаточным количеством ячеек?
|
|
|
|
|
Nov 18 2008, 11:03
|

фанат дивана
     
Группа: Свой
Сообщений: 3 387
Регистрация: 9-08-07
Из: Уфа
Пользователь №: 29 684

|
Цитата(hadrov @ Nov 18 2008, 15:32)  Я сейчас сделал еще один тестовый вариант с использованием компоненты TComPort. Там нечто подобное внутри реализовано - крутится поток и при приеме данных возникает событие, данные сохраняются в буфере. Да, это как раз очень подходящий пример. Цитата Т.к. следующее предположение верно, то можно ведь изменить пункт "Распределяем память под принятое количество байтов и копируем туда принятое;" на "один раз выделили в начале и потом просто пользуемся этим указателем до конца работы". Нет, так нельзя. Потому что пока первый блок обрабатывается (сначала стоит в очереди оконных сообщений, потом отрисовывается), второй и последующие блоки уже принимаются. В экстремальном случае (подвисание главного потока на несколько секунд) в очереди может скопиться несколько таких блоков. Так что либо так как я написал, либо, например, кольцевая очередь из заранее выделенных буферов, с передачей в сообщении номера (индекса) заполненного буфера. Но точно не один буфер. Цитата Попутно вопрос: сейчас данные приходят через фиксированные промежутки времени, данные успевают обработаться за это время, и поэтому, как я понимаю, хватает одной ячейки во втором буфере. А теперь представим ситуацию, когда данные приходят нерегулярно. Тут уже потребуется FIFO с достаточным количеством ячеек? В винде никогда нельзя закладываться на то, что программа успеет
--------------------
Если бы я знал, что такое электричество...
|
|
|
|
Сообщений в этой теме
hadrov Рисование из потока Nov 11 2008, 14:18 DpInRock В Си ошибок только прибавится. Причем, на порядок.... Nov 11 2008, 15:14 SysRq В Borland C++ Builder есть TChart.
Еще вариант ви... Nov 11 2008, 19:45 hadrov ЦитатаВ Си ошибок только прибавится. Причем, на по... Nov 12 2008, 08:37 XVR Цитата(hadrov @ Nov 12 2008, 11:37) Прогр... Nov 12 2008, 11:31 Demeny Цитата(hadrov @ Nov 11 2008, 17:18) Как с... Nov 12 2008, 10:04 SysRq Может стоит перейти на .NET? Оно относительно один... Nov 12 2008, 10:36 hadrov С учетом того, что потребуется версия для КПК, то,... Nov 12 2008, 10:46 Kopa Цитата(hadrov @ Nov 12 2008, 13:46) С уче... Nov 12 2008, 12:13 hadrov Цитатанеобходим хотя бы небольшой буфер под приним... Nov 12 2008, 11:55 XVR Цитата(hadrov @ Nov 12 2008, 14:55) Вы им... Nov 13 2008, 07:47  CSB ... Nov 17 2008, 23:00 defunct Цитата(hadrov @ Nov 12 2008, 13:55) Вот г... Dec 23 2008, 02:09 hadrov С Си знаком лучше всего.
И я не знаю как быстро ра... Nov 12 2008, 13:30 Олег Хохлов Цитата(hadrov @ Nov 11 2008, 16:18) Есть ... Nov 12 2008, 18:44 hadrov ЦитатаВоспользоваться synchronized процедурой
Ага,... Nov 17 2008, 23:14 XVR Цитата(hadrov @ Nov 18 2008, 02:14) Ага, ... Nov 18 2008, 06:45 AHTOXA Цитата(hadrov @ Nov 18 2008, 04:14) Поток... Nov 18 2008, 07:40  XVR Цитата(AHTOXA @ Nov 18 2008, 10:40) Не та... Nov 18 2008, 09:25   AHTOXA Цитата(XVR @ Nov 18 2008, 14:25) Частые з... Nov 18 2008, 09:46 hadrov ЦитатаНет, так нельзя.Теперь ясно. Я не так понял ... Nov 18 2008, 11:20
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|