Android自訂標題列

來源:互聯網
上載者:User

 

第一步,向實現自訂標題列,需要在onCreate方法裡這樣寫


requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);  
  1.   
  2. setContentView(R.layout.main);  
  3. getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.title_bar);  

注意:

requestWindowFeature要在setContentView之前

getWindow().setFeatureInit最好在setContentView之後


第二步,就是寫好自己的布局檔案,實現標題列的自訂。

不過我們會遇到一些問題,就是標題列的高度不能自訂~下面就是解決辦法~

下面,我們看一下android title標題列 在源碼 framework中的XML檔案

screen_custom_title.xml

<LinearLayout android:orientation="vertical" android:fitsSystemWindows="true">  
  1. <FrameLayout android:id="@android:id/title_container"   
  2.              android:layout_width="match_parent"   
  3.              android:layout_height="?android:attr/windowTitleSize"   
  4.              style="?android:attr/windowTitleBackgroundStyle">  
  5.     </FrameLayout>  
  6. <FrameLayout android:id="@android:id/content"   
  7.              android:layout_width="match_parent"   
  8.              android:layout_height="0dip"   
  9.              android:layout_weight="1"   
  10.              android:foregroundGravity="fill_horizontal|top"   
  11.              android:foreground="?android:attr/windowContentOverlay"/>  
  12. </LinearLayout>  

screen_title.xml

<LinearLayout android:orientation="vertical" android:fitsSystemWindows="true">  
  1. −  
  2. <FrameLayout android:layout_width="match_parent"   
  3.              android:layout_height="?android:attr/windowTitleSize"   
  4.              style="?android:attr/windowTitleBackgroundStyle">  
  5. <TextView android:id="@android:id/title"   
  6.           style="?android:attr/windowTitleStyle"   
  7.           android:background="@null"   
  8.           android:fadingEdge="horizontal"   
  9.           android:gravity="center_vertical"   
  10.           android:layout_width="match_parent"   
  11.           android:layout_height="match_parent"/>  
  12. </FrameLayout>  
  13. <FrameLayout android:id="@android:id/content"   
  14.              android:layout_width="match_parent"   
  15.              android:layout_height="0dip"   
  16.              android:layout_weight="1"   
  17.              android:foregroundGravity="fill_horizontal|top"   
  18.              android:foreground="?android:attr/windowContentOverlay"/>  
  19. </LinearLayout>  


       既然是自訂標題,那我們就看screen_custom_title.xml,裡面有一個title_container和一個content,組合成了標題列,我們自訂標題所給出的view,都被content作為子view了,影響不了那個title_container和content,所以,任你怎麼弄,它該留白的還是留白,你沒招。
       看title_container有個style是這樣的:

        style="?android:attr/windowTitleBackgroundStyle"
      

         content的foreground是這樣的android:foreground="?android:attr/windowContentOverlay"

       我們可以自己寫一個style

<resources xmlns:android="http://schemas.android.com/apk/res/android">  
  1.   
  2.   
  3. <style name="CustomWindowTitleBackground">  
  4.        <item name="android:background">#00cc00</item>  
  5. </style>  
  6.   
  7.   
  8. <style name="test" parent="android:Theme">  
  9.      <item name="android:windowTitleSize">50dp</item>  
  10.      <item name="android:windowTitleBackgroundStyle">@style/CustomWindowTitleBackground</item>  
  11. </style>  
  12. </resources>  

加入到AndroidManifest

        <activity android:name=".CustomTitileBarActivity"  
  1.                   android:label="@string/app_name" android:theme="@style/title_bar">  
  2.             <intent-filter>  
  3.                 <action android:name="android.intent.action.MAIN" />  
  4.                 <category android:name="android.intent.category.LAUNCHER" />  
  5.             </intent-filter>  
  6.         </activity>  

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.