/*
* Copyright (C) 2013 University of Washington
*
* http://creativecommons.org/licenses/by-sa/3.0/ -- code is based upon an answer on Stack Overflow:
* http://stackoverflow.com/questions/8481844/gridview-height-gets-cut
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package org.odk.collect.android.views;
import android.content.Context;
import android.util.AttributeSet;
import android.view.ViewGroup;
import android.widget.GridView;
/**
* From Stack Overflow: http://stackoverflow.com/questions/8481844/gridview-height-gets-cut
* Changed to always be expanded, since widgets are always embedded in a scroll view.
*
* @author tacone based on answer by Neil Traft
* @author mitchellsundt@gmail.com
*
*/
public class ExpandedHeightGridView extends GridView
{
public ExpandedHeightGridView(Context context)
{
super(context);
}
public ExpandedHeightGridView(Context context, AttributeSet attrs)
{
super(context, attrs);
}
public ExpandedHeightGridView(Context context, AttributeSet attrs,
int defStyle)
{
super(context, attrs, defStyle);
}
@Override
public void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
{
// HACK! TAKE THAT ANDROID!
// Calculate entire height by providing a very large height hint.
// But do not use the highest 2 bits of this integer; those are
// reserved for the MeasureSpec mode.
int expandSpec = MeasureSpec.makeMeasureSpec(
Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
super.onMeasure(widthMeasureSpec, expandSpec);
ViewGroup.LayoutParams params = getLayoutParams();
params.height = getMeasuredHeight();
}
}