2010-08-21 12 views
6

Próbuję tworzyć mniejsze karty w Androidzie - ale nie mogę tego zrobić, ponieważ wszystko, co się dzieje, gdy tworzę mniejszą zakładkę, to pokazuje większą kartę - ale bez wyciągania.Twórz mniejsze karty w Androidzie

To jest mój kod układowy dla kart teraz - ale wysokość z jakiegoś powodu nie jest zawijana - po prostu idzie na zwykłą wysokość systemu 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> 

Byłoby wspaniale, jeśli ktoś mógłby mi pomóc stworzyć coś aplikacji Facebook - Myślę, że wygląda naprawdę czyste i chciałbym zaimplementować coś podobnego:

Odpowiedz

7

Cóż to był daleko bardziej skomplikowane niż myślałem powinno być, ale mimo to powinno Ci podstawową realizację wygląd, który chcesz ...

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); 

ta nie będzie stanowiła granice tab lub rozstawu betwee jednak n elementów. Potrzebna jest również definicja listy stanów kolorów, jak poniżej w katalogu ./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> 

Nadzieję, że pomaga.

+0

Wow, to zdecydowanie więcej niż oczekiwałem, myślę, że przyjmuję tę odpowiedź, dopóki ktoś nie ogłosi bardziej pewnej metody. – hwrdprkns

+0

STATE_SELECTED i STATE_UNSELECTED mają być identyfikatorem? – pakore

+1

@pakore - Przepraszam za zaniedbanie tych definicji. STATE_SELECTED jest zdefiniowany jako równy android.R.attr.state_selected. STATE_UNSELECTED jest równy STATE_SELECTED * -1. – Woody

3

Widziałem to na innym forum, ale pomyślałem, że przekażę je tutaj.


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

Próbowałem tego i działa – Federico