• Codeby web-security - Курс "Тестирование Веб-Приложений на проникновение с нуля" от команды codeby. Общая теория, подготовка рабочего окружения, пассивный фазинг и фингерпринт, Активный фаззинг, Уязвимости, Пост-эксплуатация, Инструментальные средства, Social Engeneering и многое другое. Подробнее ...

  • Мобильный клиент нашего форума для Android гаджетов доступен в Google Play Market по этой ссылке. Клиент можно скачать с нашего форума по этой ссылке. Последняя версия МК в нашем телеграм канале вот здесь

Нужна помощь по Treeview

  • Автор темы rom@n
  • Дата начала
R

rom@n

#1
Проблема такая.
На сколько я понимаю TreeView в С++ заполняется с использованием Item[] который автоматически нумеруется сам при заполнении. А можно ли его заполнять как-нить используя другое свойство, например как в VB? где каждому Node сам присваиваешь значение свойства key. Это очень удобно при заполнении TreeView из БД где для каждой записи указывается id родительской записи.
 
R

rom@n

#3
Не пойму TTreeNode это элемент или метод для работы с TreeView?
 
R

rom@n

#5
Я не шарю по англ. )))) не могу сам разобраться ))
Были б примеры разобрался бы. Может поможешь чем, или ссылками хотя б
 
R

rom@n

#7
Нашел вот это:
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 получается что при каждом добавлении элемента просматриваются все элементы уже добавленные, пока не попадется тот куда нужно добавить. Это по-моему не правильно и совсем не быстро.
Может Есть другой способ заполнения????
 
E
#8
А сами вы надо думать писать не будете, только скопипастить?
не нравиться этот алгоритм, придумайте свой, в чем проблема?
 
R

rom@n

#9
Дак вот я и спрашиваю есть какой нить другой алгоритм, такой что бы не перебирать все записи при добавлении. Может есть какой нить другой компонент типа TreeView но похожий на TreeView в VB.
 
R

rom@n

#10
Придумал другой алгоритм. Кого интересует, создал массив, в который, при каждом добавлении записи в 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 учитывая это.
 
E
#11
Сортировать предварительно не пробовали?

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