All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.metawidget.android.widget.layout.TableLayout Maven / Gradle / Ivy

There is a newer version: 4.2
Show newest version
// Metawidget
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA

package org.metawidget.android.widget.layout;

import org.metawidget.android.widget.AndroidMetawidget;

import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout;
import android.widget.ListView;
import android.widget.TableRow;
import android.widget.TextView;

/**
 * Layout to arrange widgets in a table, with one column for labels and another for the widget.
 *
 * @author Richard Kennard
 */

public class TableLayout
	extends LinearLayout {

	//
	// Private statics
	//

	private static final int	LABEL_AND_WIDGET	= 2;

	//
	// Constructor
	//

	public TableLayout() {

		this( new LinearLayoutConfig() );
	}

	public TableLayout( LinearLayoutConfig config ) {

		super( config );
	}

	//
	// Public methods
	//

	@Override
	public void endContainerLayout( ViewGroup container, AndroidMetawidget metawidget ) {

		// If the TableLayout was never used, just put an empty space

		if ( container.getChildCount() == 0 ) {
			container.addView( new TextView( metawidget.getContext() ), new android.widget.LinearLayout.LayoutParams( ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT ) );
		}

		// Add footer

		super.endContainerLayout( container, metawidget );
	}

	//
	// Protected methods
	//

	@Override
	protected void layoutWidget( View view, ViewGroup tableRow, ViewGroup container, boolean hasLabel ) {

		// View

		View viewToAdd = view;

		// Hack for sizing ListViews

		if ( view instanceof ListView ) {
			FrameLayout frameLayout = new FrameLayout( tableRow.getContext() );

			if ( view.getLayoutParams() == null ) {
				view.setLayoutParams( new FrameLayout.LayoutParams( 325, 100 ) );
			}

			frameLayout.addView( view );

			viewToAdd = frameLayout;
		}

		// (always override LayoutParams, just in case)

		TableRow.LayoutParams params = new TableRow.LayoutParams();

		if ( !hasLabel ) {
			params.span = LABEL_AND_WIDGET;
		}

		// Add it to our layout

		tableRow.addView( viewToAdd, params );
		getLayout( container ).addView( tableRow, new android.widget.TableLayout.LayoutParams() );
	}

	@Override
	protected ViewGroup newViewToAddTo( ViewGroup container ) {

		return new TableRow( container.getContext() );
	}

	/**
	 * Initialize the TableLayout.
	 * 

* We don't initialize the TableLayout unless we find we have something to put into it, because * Android doesn't like empty TableLayouts. */ @Override protected android.widget.TableLayout getLayout( ViewGroup container ) { if ( container.getChildCount() == 0 || !( container.getChildAt( container.getChildCount() - 1 ) instanceof android.widget.TableLayout ) ) { android.widget.TableLayout layout = new android.widget.TableLayout( container.getContext() ); layout.setOrientation( android.widget.LinearLayout.VERTICAL ); layout.setColumnStretchable( 1, true ); container.addView( layout, new android.widget.LinearLayout.LayoutParams( ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT ) ); return layout; } return (android.widget.TableLayout) container.getChildAt( container.getChildCount() - 1 ); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy