(Workaround) Solution can be found at te end of my question
I've been searching for hours but I couldn't find anything that solves my problem.
I have a custom View which bassicaly draws a line from one point to another. That view is than added to the rootview.
MainActivity.java
package be.serafijnboelaert.lapse.activity;
import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.view.ViewTreeObserver;
import android.widget.GridLayout;
import android.widget.ImageButton;
import android.widget.RelativeLayout;
import android.widget.Toast;
import be.serafijnboelaert.lapse.R;
public class MainActivity extends Activity {
private RelativeLayout rl;
private GridLayout glActionMenu;
private int width;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
rl = (RelativeLayout) this.findViewById(R.id.mainContent);
rl.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
rl.getViewTreeObserver().removeOnGlobalLayoutListener(this);
setWidth(rl.getMeasuredWidth());
}
});
}
private void setWidth(int width) {
this.width = width;
glActionMenu = (GridLayout) this.findViewById(R.id.glActionMenu);
for(int i = 0 ; i < glActionMenu.getChildCount() ;i++) {
GridLayout.LayoutParams lp = new GridLayout.LayoutParams();
lp.width = width / 5;
lp.height = lp.width;
if((i >= 5 && i < 10) || (i >= 15 && i< 20)) {
lp.height = lp.width / 2 + lp.width / 4;
}
glActionMenu.getChildAt(i).setLayoutParams(lp);
}
MyCustomView myCustomView;
glActionMenu.getChildAt(glActionMenu.getChildCount() -1).addOnLayoutChangeListener(new View.OnLayoutChangeListener() {
@Override
public void onLayoutChange(View v, int left, int top, int right, int bottom, int oldLeft, int oldTop, int oldRight, int oldBottom) {
Toast.makeText(v.getContext(), "hello",Toast.LENGTH_LONG).show();
ImageButton ib1 = (ImageButton) findViewById(R.id.ibOpenPictureActivity);
ib1.setBackgroundColor(Color.RED);
ImageButton ib2 = (ImageButton) findViewById(R.id.ibOpenAlbumActivity);
ib2.setBackgroundColor(Color.GREEN);
glActionMenu.setBackgroundColor(Color.BLUE);
float fromX = ib1.getLeft() +ib1.getWidth() + rl.getLeft();
float fromY = ib1.getTop() + ib1.getHeight()/2 + glActionMenu.getTop();
float toX = ib2.getLeft();
float toY = ib2.getTop() + ib2.getHeight()/2;
MyCustomView customView = new MyCustomView(v.getContext(), fromX, fromY, toX,toY);
rl.addView(customView);
}
});
}
}
MyCustomView.java
package be.serafijnboelaert.lapse.activity;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.View;
/**
* Created by Samsung on 25/12/2014.
*/
public class MyCustomView extends View {
private float fromX;
private float fromY;
private float toX;
private float toY;
public MyCustomView(Context context, float fromX, float fromY, float toX, float toY) {
super(context);
this.fromX = fromX;
this.fromY = fromY;
this.toX = toX;
this.toY = toY;
}
public MyCustomView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public MyCustomView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
Paint paint = new Paint();
paint.setColor(Color.GREEN);
paint.setStyle(Paint.Style.STROKE);
paint.setStrokeWidth(10);
canvas.drawLine(fromX,fromY,toX,toY, paint);
}
@Override
public void onMeasure(int wms, int hms){
setMeasuredDimension(MeasureSpec.getSize(wms), MeasureSpec.getSize(hms));
}
}
activity_main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical"
tools:context=".MainActivity"
android:id="@+id/mainContent">
<include
android:layout_width="wrap_content"
android:layout_height="wrap_content"
layout="@layout/action_menu"
android:layout_gravity="center"
android:layout_centerInParent="true" />
</RelativeLayout>
action_menu.xml
<?xml version="1.0" encoding="utf-8"?>
<GridLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:columnCount="5"
android:rowCount="5"
android:columnOrderPreserved="false"
android:rowOrderPreserved="true"
android:id="@+id/glActionMenu" >
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="0"
android:layout_row="0" />
<ImageButton
android:layout_width="75dp"
android:layout_height="75dp"
android:id="@+id/ibOpenPictureActivity"
android:scaleType="fitXY"
android:background="@android:color/transparent"
android:src="@drawable/ic_picture"
android:layout_column="1"
android:layout_row="0"/>
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="2"
android:layout_row="0" />
<ImageButton
android:layout_width="75dp"
android:layout_height="75dp"
android:id="@+id/ibOpenAlbumActivity"
android:background="@android:color/transparent"
android:scaleType="fitXY"
android:layout_gravity="center_horizontal"
android:src="@drawable/ic_album"
android:layout_column="3"
android:layout_row="0" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="4"
android:layout_row="0" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="0"
android:layout_row="1" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="1"
android:layout_row="1" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="2"
android:layout_row="1" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="3"
android:layout_row="1" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="4"
android:layout_row="1" />
<ImageButton
android:layout_width="75dp"
android:layout_height="75dp"
android:id="@+id/ibOpenLapseActivity"
android:scaleType="fitXY"
android:layout_gravity="center_horizontal"
android:background="@android:color/transparent"
android:src="@drawable/ic_lapse"
android:layout_column="0"
android:layout_row="2" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="1"
android:layout_row="2" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="2"
android:layout_row="2" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="3"
android:layout_row="2" />
<ImageButton
android:layout_width="75dp"
android:layout_height="75dp"
android:id="@+id/ibOpenSettingsActivity"
android:background="@android:color/transparent"
android:scaleType="fitXY"
android:layout_gravity="center_horizontal"
android:src="@drawable/ic_settings"
android:layout_column="4"
android:layout_row="2" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="0"
android:layout_row="3" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="1"
android:layout_row="3" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="2"
android:layout_row="3" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="3"
android:layout_row="3" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="4"
android:layout_row="3" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="0"
android:layout_row="4" />
<ImageButton
android:layout_width="75dp"
android:layout_height="75dp"
android:id="@+id/btnOpenShareActivity"
android:scaleType="fitXY"
android:background="@android:color/transparent"
android:src="@drawable/ic_share"
android:layout_column="1"
android:layout_row="4" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="2"
android:layout_row="4" />
<ImageButton
android:layout_width="75dp"
android:layout_height="75dp"
android:id="@+id/ibOpenHelpActivity"
android:scaleType="fitXY"
android:layout_gravity="center_horizontal"
android:background="@android:color/transparent"
android:src="@drawable/ic_help"
android:layout_column="3"
android:layout_row="4" />
<View
android:layout_width="75dp"
android:layout_height="75dp"
android:layout_column="4"
android:layout_row="4" />
</GridLayout>
The problem is, that the onDraw method from my customview is never called, but the other layout changes (buttons in green and red and gridlayout in blue) works fine..
I need that line to be drawad AFTER the layoutchanges from the actionbuttons, because the line simply connects two action buttons with eachother.
I know, I set an GlobalLayoutChangeListerer on every button, it's pretty useless but thats for testing purposes.
I really hope I can find the solution here.
Thnx in advance!
(Workaround) Solution
package be.serafijnboelaert.lapse.activity;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewTreeObserver;
import android.widget.GridLayout;
import android.widget.ImageButton;
import android.widget.RelativeLayout;
import be.serafijnboelaert.lapse.R;
public class MainActivity extends Activity {
private RelativeLayout rl;
private GridLayout glActionMenu;
private int width;
private float fromX;
private float fromY;
private float toX;
private float toY;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
rl = (RelativeLayout) this.findViewById(R.id.mainContent);
rl.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
rl.getViewTreeObserver().removeOnGlobalLayoutListener(this);
setWidth(rl.getMeasuredWidth());
}
});
}
private void setWidth(int width) {
this.width = width;
glActionMenu = (GridLayout) this.findViewById(R.id.glActionMenu);
for(int i = 0 ; i < glActionMenu.getChildCount() ;i++) {
GridLayout.LayoutParams lp = new GridLayout.LayoutParams();
lp.width = width / 5;
lp.height = lp.width;
if((i >= 5 && i < 10) || (i >= 15 && i< 20)) {
lp.height = lp.width / 2 + lp.width / 4;
}
glActionMenu.getChildAt(i).setLayoutParams(lp);
}
glActionMenu.addOnLayoutChangeListener(new View.OnLayoutChangeListener() {
@Override
public void onLayoutChange(View v, int left, int top, int right, int bottom, int oldLeft, int oldTop, int oldRight, int oldBottom) {
ImageButton ib1 = (ImageButton) findViewById(R.id.ibOpenPictureActivity);
ImageButton ib2 = (ImageButton) findViewById(R.id.ibOpenAlbumActivity);
fromX = ib1.getRight() + rl.getLeft();
fromY = ib1.getTop() + ib1.getHeight()/2 + glActionMenu.getTop();
toX = ib2.getLeft();
toY = ib2.getTop() + ib2.getHeight()/2 + glActionMenu.getTop();
}
});
glActionMenu.postDelayed(new Runnable()
{
@Override
public void run()
{
MyCustomView customView = new MyCustomView(MainActivity.this, fromX, fromY, toX, toY);
rl.addView(customView);
}
}, 10);
}
}