Поиск:

Ответ в темуСоздание новой темы Создание опроса
> TChart TTowerSeries не отображаются все точки 
V
    Опции темы
Michrutka
Дата 8.6.2010, 12:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Здравствуйте, граждане Форумчане!
имею следующую ситуацию:
есть матрица резуьтатов n x m результатов экспериментов.
ее необходимо визуализировать в виде баров (поверхности) в 3D графике.
делаю следующим образом
Код

//*.h
TTowerSeries *Series3DResult;
//*.cpp
    Series3DResult->Clear();
    for(int j = 0; j < N; ++j)
    {
            double y = ...;
            double x = ...;
            double z = ...;
            Series3DResult->AddXYZ(x, y, z);
    }

при этом имею такую картинку:
user posted image
первые ряды по X и Z почему то не отображаются, хотя есть - лейблы на них есть.
с чем этио может быть связано и как это победить.
подскажите пожалуйста.
зы использую TChart 8
Заранее Спасибо
PM MAIL   Вверх
lyucean
  Дата 8.6.2010, 17:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



попробуй уменьшить размер площадок, возможно просто баг. 
Могу скинуть код вывода 3д изображения ..можешь нарисовать их сам на имейдже или форме, если так надо smile 
PM MAIL   Вверх
Michrutka
Дата 9.6.2010, 08:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



lyucean, спасибо
Уменьшение размеров площадок никак не влияло.
скинь, посмотрю. вдруг я там что не так делаю.

PM MAIL   Вверх
lyucean
Дата 10.6.2010, 10:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(Michrutka @ 9.6.2010,  08:02)
lyucean, спасибо
Уменьшение размеров площадок никак не влияло.
скинь, посмотрю. вдруг я там что не так делаю.

Код

void Risuem_cub(double& r,double& a,double& b,double& c,double& num)
{

        double ImX,ImY;
        double ugol=Form1->Edit1->Text.ToDouble();
        Form1->Im->Canvas->Pen->Width=1;
        Form1->Im->Canvas->Brush->Color=clBlack;
        Form1->Im->Canvas->Pen->Color=clRed;
        
        double H=sin(ugol*M_PI/360/3)*b+c*(cos(ugol*M_PI/360*2/3));
        for(int i=0;i<a+r;i=i+r)
        {
                if(num==0)
                {
                        Form1->Im->Canvas->Brush->Color=Form1->Im->Canvas->Pen->Color;

                        ImX= i;
                        ImY=(1+sin(ugol*M_PI/360))*H-c;
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);

                        ImX= i;
                        ImY=(1+sin(ugol*M_PI/360))*H;
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);
                }
                else
                {
                        if(i==0)
                        {
                                Form1->Im->Canvas->Pen->Color=Form1->Im->Canvas->Brush->Color;
                                Form1->Im->Canvas->Rectangle(0,0,Form1->Im->Width,Form1->Im->Height);
                                Form1->Im->Canvas->Pen->Color=clRed;
                        }

                        ImX= i+b*cos(ugol*M_PI/360);
                        ImY=(1+sin(ugol*M_PI/360))*H - c - b*sin(ugol*M_PI/360);
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);

                        ImX= i+b*cos(ugol*M_PI/360);
                        ImY=(1+sin(ugol*M_PI/360))*H - b*sin(ugol*M_PI/360);
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);;
                }
        }

        Form1->Im->Canvas->Pen->Color=clLime;
        for(int i=0;i<b+r;i=i+r)
        {
                if(num==0)
                {
                        Form1->Im->Canvas->Brush->Color=Form1->Im->Canvas->Pen->Color;

                        ImX=a+i*cos(ugol*M_PI/360);
                        ImY=(1+sin(ugol*M_PI/360))*H- i*sin(ugol*M_PI/360);
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);

                        ImX=a+i*cos(ugol*M_PI/360);
                        ImY=(1+sin(ugol*M_PI/360))*H-c- i*sin(ugol*M_PI/360);
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);
                }
                else
                {
                        ImX=i*cos(ugol*M_PI/360);
                        ImY=(1+sin(ugol*M_PI/360))*H-c- i*sin(ugol*M_PI/360);
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);

                        ImX=i*cos(ugol*M_PI/360);
                        ImY=(1+sin(ugol*M_PI/360))*H- i*sin(ugol*M_PI/360);
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);
                }
        }

        Form1->Im->Canvas->Pen->Color=clYellow;
        for(int i=0;i<c+r;i=i+r)
        {
                if(num==0)
                {
                        Form1->Im->Canvas->Brush->Color=Form1->Im->Canvas->Pen->Color;

                        ImX=0;
                        ImY=(1+sin(ugol*M_PI/360))*H-i;
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);

                        ImX=a;
                        ImY=(1+sin(ugol*M_PI/360))*H-i;
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);

                        ImX=a+b*cos(ugol*M_PI/360);
                        ImY=(1+sin(ugol*M_PI/360))*H-i- b*sin(ugol*M_PI/360);
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);
                }
                else
                {
                        ImX=b*cos(ugol*M_PI/360);
                        ImY=(1+sin(ugol*M_PI/360))*H-i- b*sin(ugol*M_PI/360);
                        Form1->Im->Canvas->Ellipse(ImX-r,ImY-r,ImX+r,ImY+r);
                }
        }
        Form1->Im->Canvas->Pen->Color=Form1->Im->Canvas->Brush->Color;
}


возникнут вопросы ..спрашивай .. smile 
PM MAIL   Вверх
Michrutka
Дата 10.6.2010, 15:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Проблему обошел добавлением нулевого столбца и строки (нулевые не видны, но зато видны информативные столбцы)
вдруг кому поможет.
и все таки интересно - что там не так.

lyucean, Спасибо
PM MAIL   Вверх
lyucean
Дата 5.11.2010, 15:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(Michrutka @ 10.6.2010,  15:09)
Проблему обошел добавлением нулевого столбца и строки (нулевые не видны, но зато видны информативные столбцы)
вдруг кому поможет.
и все таки интересно - что там не так.

lyucean, Спасибо

Если не трудно, выложи кусок кода, тоже понадобилось вывести поверхность на TChart, сижу велосипед придумываю.  smile 
PM MAIL   Вверх
Michrutka
Дата 8.11.2010, 11:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Пожалуйста. но там ничего примечатльного - добавляем нулевуюб строчку и столбец и данные начиная с 1
Код

for(int j = 0; j < Cols; ++j) 
    {
        Series3DResult->AddXYZ(j+1, 0, 0);
    }
    for(int j = 0; j < Rows; ++j)
    {
        Series3DResult->AddXYZ(0, 0,j+1);
    }
    for(int j = 0; j < NumOfChannels; ++j)
    {
        if(RawDataCheckBoxGrid->Checked(j))
        {
            double y = RawDataResult[j];
            double x = j%Cols+1;
            double z = Rows - (j/Cols+1)+1;
            Series3DResult->AddXYZ(x, y, z);
        }
    }

PM MAIL   Вверх
lyucean
  Дата 8.11.2010, 14:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Спасибо, разобрался, у меня почему-то в версии 8.04 нет такой проблемы.

Это сообщение отредактировал(а) lyucean - 8.11.2010, 15:26
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++ Builder"
Rrader

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

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

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

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


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

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


 




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


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

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