Entire library code converted to Kotlin for better stability and reducing null pointer errors though could be used with java as well
2D scrolling mode added, keep in mind this comes with few limitations: you won't be able not place views on right side like alignParentRight. Everything should be align left. Is not enabled by default
Click here for info on how to use this library in your android application.
-
- N - level expandable/collapsable tree
-
- Custom values, views, styles for nodes
-
- Save state after rotation
-
- Selection mode for nodes
-
- Dynamic add/remove node
- For Android 4.0 (+/- nearest version) if you have too deep view hierarchy and with tree its easily possible, your app may crash
1) Add library as a dependency to your project
implementation 'com.github.SmailBarkouch:android-treeview:1.0.0'
2) Create your tree starting from root element. TreeNode.root()
element will not be displayed so it doesn't require anything to be set.
val root = TreeNode.root()
Create and add your nodes (use your custom object as constructor param)
val parent = TreeNode("MyParentNode")
val child0 = TreeNode("ChildNode0")
val child1 = TreeNode("ChildNode1")
parent.addChildren(child0, child1)
root.addChild(parent)
3) Add tree view to layout
val tView = AndroidTreeView(getActivity(), root)
containerView.addView(tView.getView())
The simplest but not styled tree is ready. Now you can see parent
node as root of your tree
4) Custom view for nodes
Extend TreeNode.BaseNodeViewHolder
and overwrite createNodeView
method to prepare custom view for node:
class MyHolder : TreeNode.BaseNodeViewHolder<IconTreeItem> {
...
override fun createNodeView(val node, val value) : View?{
val inflater = LayoutInflater?.from(context)
val view = inflater?.inflate(R.layout.layout_profile_node, container, false)
val tvValue = view?.findViewById(R.id.node_value) as? TextView
tvValue.setText(value.text)
return view
}
...
class IconTreeItem {
val icon
val text
}
}
5) Connect view holder with node
val nodeItem = IconTreeItem()
val child1 = TreeNode(nodeItem).setViewHolder(new MyHolder(mContext))
6) Consider using
TreeNode.setClickListener(TreeNodeClickListener listener)
AndroidTreeView.setDefaultViewHolder
AndroidTreeView.setDefaultNodeClickListener
...