2010-08-21 10 views
6

Sto cercando di creare schede più piccole in Android - ma non riesco a farlo funzionare perché tutto ciò che accade quando creo una scheda più piccola è che mostra la scheda più grande - ma senza un drawable.Crea schede più piccole in Android

Questo è il mio codice di layout per le schede ora - ma l'altezza non è avvolgente per qualche motivo - va solo all'altezza di layout abituale di Android.

<TabHost xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@android:id/tabhost" android:layout_width="fill_parent" 
    android:layout_height="fill_parent"> 
    <LinearLayout android:orientation="vertical" 
     android:layout_width="fill_parent" android:layout_height="fill_parent"> 
     <TabWidget android:id="@android:id/tabs" 
      android:layout_width="fill_parent" android:layout_height="wrap_content" /> 
     <FrameLayout android:id="@android:id/tabcontent" 
      android:layout_width="fill_parent" android:layout_height="fill_parent"> 
     </FrameLayout> 
    </LinearLayout> 
</TabHost> 

Sarebbe bello se qualcuno potesse aiutarmi a creare qualcosa di simile l'applicazione Facebook - penso che sembra davvero pulito e mi piacerebbe implementare qualcosa di simile:

risposta

7

Beh questo è stato di gran lunga più complicato di quanto ho pensato che dovrebbe essere ma, tuttavia, questo dovrebbe farti un'implementazione di base del l'aspetto che si desidera ...

TabHost    host  = getTabHost(); 
TabSpec    spec  = null; 
TextView   tab1  = null, 
        tab2  = null; 
Intent    intent  = null; 
Resources   resources = getResources(); 
XmlResourceParser parser  = null; 
ColorStateList  text  = null; 
StateListDrawable[] drawables = new StateListDrawable[2]; 
int[]    selected = {STATE_SELECTED}, 
        unselected = {STATE_UNSELECTED}; 
Color    selectedColor = Color.argb(255, 255, 255, 255), 
        defaultColor = Color.argb(255, 119, 119, 119); 

// Load the colour lists. 
parser = resources.getXml(R.color.tab_text); 
text = ColorStateList.createFromXml(getResources(), parser); 

// Add an initial tab. 
...Create Tab Contents Here... 
spec = host.newTabSpec("tab1"); 
tab1 = new TextView(this); 
tab1.setText(R.string.all_tab_title); 
tab1.setGravity(android.view.Gravity.CENTER); 
tab1.setTextSize(18.0f); 
tab1.setTextColor(text); 
spec.setIndicator(tab1); 
spec.setContent(intent); 
host.addTab(spec); 

// Add a second tab. 
...Create Tab Contents Here... 
spec = host.newTabSpec("tab2"); 
tab2 = new TextView(this); 
tab2.setText(R.string.category_tab_title); 
tab2.setGravity(android.view.Gravity.CENTER); 
tab2.setTextSize(18.0f); 
tab2.setTextColor(text); 
spec.setIndicator(tab2); 
spec.setContent(intent); 
host.addTab(spec); 

// Set the background drawable for the tabs and select the first tab. 
drawables[0] = new StateListDrawable(); 
drawables[0].addState(selected, new ColorDrawable(selectedColor)); 
drawables[0].addState(unselected, new ColorDrawable(defaultColor)); 
drawables[1] = new StateListDrawable(); 
drawables[1].addState(selected, new ColorDrawable(selectedColor)); 
drawables[1].addState(unselected, new ColorDrawable(defaultColor)); 
tab1.setBackgroundDrawable(drawables[0]); 
tab2.setBackgroundDrawable(drawables[1]); 
host.setCurrentTab(0); 

questo non rappresenterà per i bordi della scheda o la spaziatura betwee n elementi però. È inoltre necessario un definizione di elenco stato di colore come il seguente nella directory ./res/color ...

<?xml version="1.0" encoding="UTF-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
    <item android:state_selected="true" android:color="#ff000000" /> 
    <item android:state_selected="false" android:color="#ffaaaaaa" /> 
    <item android:color="#ffffffff"/> 
</selector> 

Speranza che aiuta.

+0

Wow, questo è sicuramente molto più di quello che stavo cercando, suppongo che accetterò questa risposta fino a quando qualcuno invierà un modo più sicuro. – hwrdprkns

+0

STATE_SELECTED e STATE_UNSELECTED dovrebbero essere id di cosa? – pakore

+1

@pakore - Ci scusiamo per aver trascurato queste definizioni. STATE_SELECTED è definito come uguale a android.R.attr.state_selected. STATE_UNSELECTED è uguale a STATE_SELECTED * -1. – Woody

3

Ho visto questo in un altro forum, ma ho pensato di passare qui.


TabHost th = getTabHost(); 
.... 
// Setup all the tabs -- in my case, with text only -- no icons 
.... 
int iCnt = th.getTabWidget().getChildCount(); 
for(int i=0; i&ltiCnt; i++) 
    th.getTabWidget().getChildAt(i).getLayoutParams().height /= 2; // Or the size desired 
+0

Ho provato questo e funziona – Federico

Problemi correlati