Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Нужна помощь по Treeview
Форум программистов > Системное программирование > C, С++ и С Builder > Borland C++ Builder & Kylix
rom@nыч
Проблема такая.
На сколько я понимаю TreeView в С++ заполняется с использованием Item[] который автоматически нумеруется сам при заполнении. А можно ли его заполнять как-нить используя другое свойство, например как в VB? где каждому Node сам присваиваешь значение свойства key. Это очень удобно при заполнении TreeView из БД где для каждой записи указывается id родительской записи.
etc
см TTreeNode.Data
rom@nыч
Не пойму TTreeNode это элемент или метод для работы с TreeView?
etc
rom@nыч F1
rom@nыч
Я не шарю по англ. )))) не могу сам разобраться ))
Были б примеры разобрался бы. Может поможешь чем, или ссылками хотя б
etc
Цитата(rom@nыч @ 11:06:2008 - 09:39) *
Были б примеры разобрался бы
F1 + Demos
rom@nыч
Нашел вот это:
DMod->SPBrowStruk->Params->ParamValues["@ParentID"]=0;
DMod->SPBrowStruk->Params->ParamValues["@Pokaz"]=0;
DMod->SPBrowStruk->ExecProc(); //получаем все узлы
DMod->SPBrowStruk->Active=true;
DMod->SPBrowStruk->First();
while(!DMod->SPBrowStruk->Eof)
{
DanNod=new TDanNod;
DanNod->IDPodr= DMod->SPBrowStruk->Fields->FieldByName("idNode")->AsInteger;
DanNod->IDParent= DMod->SPBrowStruk->Fields->FieldByName("idParent")->AsInteger;
DanNod->Name= DMod->SPBrowStruk->Fields->FieldByName("NodeName")->AsString;
if(DMod->SPBrowStruk->Fields->FieldByName("idParent")->AsInteger==0) //если узел корневой
{
TV->Items->AddObject(NULL, DMod->SPBrowStruk->Fields->
FieldByName("NodeName")->AsString, DanNod);
}
else //в противном случае находим родителя и добавляем узел к нему подчиненным
{
int iCount=TV->Items->Count;
for(int j=0; j<iCount; j++)
{
TDanNod *dat;
dat=(TDanNod*)TV->Items->Item[j]->Data;
if(dat)
{
if(DMod->SPBrowStruk->Fields->FieldByName("idParent")->AsInteger==dat->IDPodr)
{
TV->Items->AddChildObject(TV->Items->Item[j],
DMod->SPBrowStruk->Fields->FieldByName("NodeName")->AsString,
DanNod);
break;
}
}
}
}
DMod->SPBrowStruk->Next();
}
DMod->SPBrowStruk->Active=false;

Как работае понял, но еще пока не пробовал на практике.

Но при таком заполнении TreeView получается что при каждом добавлении элемента просматриваются все элементы уже добавленные, пока не попадется тот куда нужно добавить. Это по-моему не правильно и совсем не быстро.
Может Есть другой способ заполнения????
etc
А сами вы надо думать писать не будете, только скопипастить?
не нравиться этот алгоритм, придумайте свой, в чем проблема?
rom@nыч
Дак вот я и спрашиваю есть какой нить другой алгоритм, такой что бы не перебирать все записи при добавлении. Может есть какой нить другой компонент типа TreeView но похожий на TreeView в VB.
rom@nыч
Придумал другой алгоритм. Кого интересует, создал массив, в который, при каждом добавлении записи в TreeView, записывал номер добавляемого Item'а
Вот код:
ADOTableGroup->Last();
int tgc = ADOTableGroup->FieldByName("id")->AsInteger;
int *ArrGroup = new int[tgc];
int i=0;
TreeView->Items->Clear();
TreeView->Items->Add(NULL,"XXX");
ADOTableGroup->First();
ArrGroup[0] = 0;
while (!ADOTableGroup->Eof)
{
i++;
ArrGroup[ADOTableGroup->FieldByName("id")->AsInteger] = i;
TreeView->Items->AddChild(TreeView->Items->Item[ArrGroup[ADOTableGroup->FieldByName("Group")->AsInteger]],ADOTableGroup->FieldByName("Name")->AsString);
ADOTableGroup->Next();
}

Но возникает другая проблема: если дочерняя запись в Базе Данных находится раньше, по отношению к родительской, то возникнет ошибочка несуществующей родительской записи.
Может подскажете как можно организовать заполнение более удобно TreeView учитывая это.
etc
Сортировать предварительно не пробовали?

или фильтровать, что гдето равнозначно ...
rom@nыч
Цитата(etc @ 11:06:2008, 19:48 ) *
Сортировать предварительно не пробовали?

или фильтровать, что гдето равнозначно ...

Спасибо, уже сам сделал. Сразу что то сам не догадался.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Форум IP.Board © 2001-2008 IPS, Inc.