0 / 0 / 0
Регистрация: 08.01.2013
Сообщений: 8
1

Создание кластеров в графе. Сворачивание вершин

01.02.2016, 00:34. Показов 1154. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть библиотека vis.js , позволяющая отрисовать графы разных видов и производить какие-либо манипуляции с ними. В том числе можно свернуть несколько вершин в кластер (то есть спрятать несколько маленьких вершин в одну большую, например). Я поняла, как разворачиваются эти вершины, но вот алгоритм сворачивания не могу уловить. В функцию передаем scale - то есть значение "зума". Логика такая: маленький масштаб - все вершины прячем в кластеры, большой - полностью разворачиваем граф. Что примечательно, кластер может прятаться в кластер.

Javascript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
    function makeClusters(scale) {
        var clusterOptionsByData = {
            processProperties: function (clusterOptions, childNodes) {
                clusterIndex = clusterIndex + 1;
                var childrenCount = 0;
                for (var i = 0; i < childNodes.length; i++) {
                    childrenCount += childNodes[i].childrenCount || 1;
                }
                clusterOptions.childrenCount = childrenCount;
                clusterOptions.label = "# " + childrenCount + "";
                clusterOptions.font = {size: childrenCount*5+30}
                clusterOptions.id = 'cluster:' + clusterIndex;
                clusters.push({id:'cluster:' + clusterIndex, scale:scale});
                return clusterOptions;
            },
            clusterNodeProperties: {borderWidth: 3, shape: 'database', font: {size: 30}}
        }
Вообще не понятна вот эта строчка:
Javascript
1
processProperties: function (clusterOptions, childNodes)
Чем может быть processProperties ?

И не очень понятна логика действий вот тут:
Javascript
1
2
3
for (var i = 0; i < childNodes.length; i++) {
                    childrenCount += childNodes[i].childrenCount || 1;
                }
Источник:
https://github.com/almende/vis... work/other
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.02.2016, 00:34
Ответы с готовыми решениями:

Вывести центроиды кластеров графе, представленным матрицей
Всем привет. Имеем граф, представленный матрицей nxm (n==m), где A=кратчайший путь из n1 в m1 и...

Как найти число вершин и ребер в графе окресности каждой пары вершин
Как найти число вершин и ребер в графе окресности каждой пары вершин? Добавлено через 5 минут В...

Номера вершин в графе
Здравствуйте! Я уже задавал здесь подобный вопрос, однако никто ответить однозначно не смог,...

Нумерация вершин в графе
Здравствуйте! Как известно, нумерация вершин в графе принята от 0 до n. Например: 0 1 1 2...

1
Ренегат
Эксперт HTML/CSS
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
01.02.2016, 22:34 2
Anett, не знаю что такое processProperties, но думаю, что это типа "обработчика свойств"
то есть он смотрит на все свойства, потом думает что с ними делать, потом отдаёт какие-то другие свойства или результат размышлений
а строчка
Javascript
1
childrenCount += childNodes[i].childrenCount || 1;
просто суммирует всех чилдов(вершин)
то есть она перебирает всех чилдов переданного ей графика или я не знаю чего там передаётся
и потом просто суммируются число чилдов этих чилдов(тофтология 1000lvl) и если у вершины нету чилдов, то просто приплюсовывает эту вершину
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.02.2016, 22:34
Помогаю со студенческими работами здесь

Сколько в этом графе вершин и рёбер?
В плоском двусвязном графе 7 граней (считая внешнюю) - 3 треугольника, 3 четырехугольника и...

Смежность и инцидентность ребер и вершин в графе.
Нужно взять любой граф (желательно попроще), ввести его програму. потом вводим 2 вершины, программа...

Алгоритм нахождения вершин маршрута в графе
По запросам в поисковике всё время выдаёт решение на тему поиск кратчайшего пути, мне это не нужно,...

Определить множество вершин, максимально удаленных от корня, на графе
Для ориентированного графа G с вершинами v(i) є v(|V| &lt;= 80) и ребрами е(k) є E (|E| &lt;= 150)...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru