As @SergePopulov said, NonHierarchicalDistanceBasedAlgorithm does not implement removing elements. For those who dont want to use GridBasedAlgoritm but still needs to remove single elements from NonHierarchicalDistanceBasedAlgorithm there is another solution.
Using this link (Source) you can find source code for the NonHierarchicalDistanceBasedAlgorithm provided by developers in github.
What I did is just save the old Cluster items, clear the clusterManager and add the old items again but do not add the one that is passed through the method.
Firstly create a separate class and paste NonHierarchicalDstanceBasedAlgorithm class code.
public class CustomNonHierarchicalDistanceBasedAlgorithm<MarkerItem extends ClusterItem> implements Algorithm<MarkerItem>
{
//copy code here
}
After that find method removeItem and replace it with this code:
@Override
public void removeItem(MarkerItem item)
{
final Collection<QuadItem<MarkerItem>> items = new ArrayList<QuadItem<MarkerItem>>();
final PointQuadTree<QuadItem<MarkerItem>> quadTree = new PointQuadTree<QuadItem<MarkerItem>>(0, 1, 0, 1);
for (QuadItem<MarkerItem> temp : mItems)
{
if (item.getPosition() != temp.getPosition())
{
synchronized (quadTree)
{
items.add(temp);
quadTree.add(temp);
}
}
}
clearItems();
for (QuadItem<MarkerItem> temp : items)
{
synchronized (mQuadTree)
{
mItems.add(temp);
mQuadTree.add(temp);
}
}
}
After that go where your ClusterManager is created and paste code below containing your class name:
clusterManager.setAlgorithm(new CustomNonHierarchicalDistanceBasedAlgorithm<MarkerItem>());
Where your MarkerItem is your class which implemented ClusterItem. And it should now work.
Don't forget to recluster your ClusterManager after you remove the item by running:
clusterManager.cluster();
PreCachingAlgorithmDecorator
is unnecessary as it automatically does this in thesetAlgorithm()
method. – Gonad