I’ve got an example layout that I’m trying to create in android using xml. I am able to create similar layouts but I feel as if my approach might be wrong.
What I have been doing in these cases is nesting relative layouts to act as a “row”. The below image demonstrates what I would do.

How would you guys create a layout similar to this? I feel as if nesting relative layouts is overkill but I’m not sure how I can keep everything centred if I don’t.
When I didn’t nest the layouts I used
android:layout_toRightOf="..."
android:layout_below="@+id/t1"
on t5, t6 and t7 (from the image). The result looked incorrect. t1, t2, t3 and t4 wasn’t centred horizontally any more.
Is there a way to like tell the relative layout that everything after this point should appear on a new row? Or is relative layouts the wrong way to go for things like this? I don’t think a table layout would work correctly since each row doesn’t necessarily need to have the same amount of views and they need to be centred.
Any suggestions appreciated!
You could nest two horizontal
LinearLayoutswithin a verticalLinearLayout. Maybe not so efficient as aRelativeLayout, but easier to get the centering behavior you want.Here’s another version of the same layout using
RelativeLayout. I started with the nestedLinearLayoutsabove, selected “Refactor > Android > Change Layout…“, selectedRelativeLayout, and then tweaked the resulting layout until I got things centered.I used a couple of tricks to get it right. I started by centering the middle button on the parent, then built out to the left and right. On the top row, where there is an even number of buttons and space in the center, I used a centered, 0-width
TextViewto anchor the buttons. That’s a bit hacky, I guess, but it gets the job done. 🙂