B4J Library [B4X] A B4XPages Class for Displaying a Flexible Horizontal Tree

The specs for this class are flexible and simple to define.
It works on B4J and B4A.
It is a significant expansion of the proof of concept posted Here
The class is included in the attached. Please use and/or modify for your purposes.


hTreeChart.png

Use:
B4X:
Private Sub B4XPage_Created (Root1 As B4XView)
    Root = Root1
 
    Private targetPanel As B4XView = xui.CreatePanel("")
    targetPanel.SetLayoutAnimated(0, 0dip, 0dip, Root.width, Root.height)
    Private styles As Map = CreateMap()
    'targetPanel.SetColorAndBorder(xui.Color_Transparent, 1, xui.Color_RGB(220, 220, 220), 0)

    styles.Put("Title", CreateMap("text": "A Flexible Horizontal Tree Chart", "textColor": xui.Color_RGB(0, 160, 0), "textSize": 25, "align": "center"))
    styles.Put("Notes", CreateMap("noteHeight": 25, "lines": CreateList(Array( _
            CreateMap("text": "Note 1: Red on gray are 'Special'", "textColor": xui.Color_RGB(100, 100, 100), "textSize": 15, "align": "left"), _
            CreateMap("text": "Note 2: Others are defaults", "textColor": xui.Color_RGB(100, 100, 100), "textSize": 15, "align": "left") _
    ))))
    styles.Put("Connectors", CreateMap("color": xui.Color_RGB(160, 160, 160), "width": 2))
    styles.Put("Default", CreateMap("color": xui.Color_Blue, "bold": False, "textSize": 18, "borderColor": xui.Color_Blue))
    styles.Put("StyleA", CreateMap("color": xui.Color_Red, "bold": True, "textSize": 20, _
    "backgroundColor": xui.Color_RGB(200, 200, 200), "borderColor": xui.Color_Black, "borderWidth": 2, "borderRadius": 5))
     
    'Column index = level = number of leading tabs; | specifies row position; styles see above
    Dim spec As String = $"
Item 1|10, StyleA
    Item 1-1|8
        Item 1-1-1|3
        Item 1-1-2|4
    Item 1-2|9
        Item 1-2-1|9
        Item 1-2-2|10, StyleA
    Item 1-3|10
        Item 1-3-1|15
    "$

    'The width of the panel and number of columns determine the width of each box
    'The height of the panel and number of rows determine the height of each box
    htree.Initialize(targetPanel, 17, 4, False, styles, spec)
    B4XPages.AddPageAndCreate("htree", htree)
    Sleep(0)
    B4XPages.ShowPage("htree")

    'grab and resize chart 
#if B4J 
    Dim im As ImageView
    im.Initialize("")
    Root.AddView(im, 100, 100, 600, 400)
    im.SetImage(htree.getBitmap)
#End if

End Sub
 

Attachments

  • hTree_V4.01.zip
    36.1 KB · Views: 105
Last edited:

kimstudio

Active Member
Licensed User
Longtime User
Hi Bill the chart looks very elegant, thanks!

When use the following spec the connector drawing may have issue:

B4X:
    Dim spec As String = $"
Item 1|10, StyleA
    Item 1-1|7
        Item 1-1-1|3
        Item 1-1-2|4
        Item 1-1-3|5
            Item 1-1-3|7
    Item 1-2|9
        Item 1-2-1|9  
        Item 1-2-2|10, StyleA
            Item 1-1-3|12
    Item 1-3|10
        Item 1-3-1|15
    "$

屏幕截图 2024-03-02 090802.png
 

William Lancee

Well-Known Member
Licensed User
Longtime User
@kimstudio It wasn't the connection algorithm, but the additional parts at the end, which required 2 pops of the stack instead of 1.
Fix v4.01 is in #1.

A reminder to all, the parser requires TABs as indents, not leading spaces. You could modify the parser to use something else.
Or add this line after defining spec. Where the #spaces is what represents one TAB.
B4X:
    If Not(spec.Contains(TAB)) Then spec = spec.Replace("   ", TAB)

hTreeChart.png
 
Last edited:
Top