SceneIndexManager.java 1.28 KB
Newer Older
Akka's avatar
Akka committed
1
2
package emu.grasscutter.scripts;

3
4
5
6
import com.github.davidmoten.rtreemulti.Entry;
import com.github.davidmoten.rtreemulti.RTree;
import com.github.davidmoten.rtreemulti.geometry.Geometry;
import com.github.davidmoten.rtreemulti.geometry.Rectangle;
Akka's avatar
Akka committed
7
8

import java.util.ArrayList;
Akka's avatar
Akka committed
9
import java.util.Collection;
Akka's avatar
Akka committed
10
11
12
13
14
import java.util.List;
import java.util.function.Function;

public class SceneIndexManager {

15
16
17
    public static <T> RTree<T, Geometry> buildIndex(int dimensions, Collection<T> elements, Function<T, Geometry> extractor){
        RTree<T, Geometry> rtree = RTree.dimensions(dimensions).create();
        return rtree.add(elements.stream().map(e -> Entry.entry(e, extractor.apply(e))).toList());
Akka's avatar
Akka committed
18
    }
19
    public static <T> List<T> queryNeighbors(RTree<T, Geometry> tree, double[] position, int range){
Akka's avatar
Akka committed
20
        var result = new ArrayList<T>();
21
22
23
        Rectangle rectangle = Rectangle.create(calRange(position, -range), calRange(position, range));
        var queryResult = tree.search(rectangle);
        queryResult.forEach(q -> result.add(q.value()));
Akka's avatar
Akka committed
24
25
        return result;
    }
26
    private static double[] calRange(double[] position, int range){
Akka's avatar
Akka committed
27
        var newPos = position.clone();
28
        for(int i=0;i<newPos.length;i++){
Akka's avatar
Akka committed
29
30
31
32
33
            newPos[i] += range;
        }
        return newPos;
    }
}