• Познакомьтесь с пентестом веб-приложений на практике в нашем новом бесплатном курсе

    «Анализ защищенности веб-приложений»

    🔥 Записаться бесплатно!

  • CTF с учебными материалами Codeby Games

    Обучение кибербезопасности в игровой форме. Более 200 заданий по Active Directory, OSINT, PWN, Веб, Стеганографии, Реверс-инжинирингу, Форензике и Криптографии. Школа CTF с бесплатными курсами по всем категориям.

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

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

rom@n

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

rom@n

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

rom@n

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

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

etc

А сами вы надо думать писать не будете, только скопипастить?
не нравиться этот алгоритм, придумайте свой, в чем проблема?
 
R

rom@n

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

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 учитывая это.
 
E

etc

Сортировать предварительно не пробовали?

или фильтровать, что гдето равнозначно ...
 
Мы в соцсетях:

Обучение наступательной кибербезопасности в игровой форме. Начать игру!