没有样式ViewPagerIndicator与SherlockActionBar结合使用

use*_*553 24 android android-theme android-viewpager actionbarsherlock

我正在尝试使用SherlockActionBar实现ViewPagerIndicator.它的工作原理:我可以滑动碎片,但风格不起作用!

它看起来像这样:

IMG

相关主题:https://github.com/JakeWharton/Android-ViewPagerIndicator/issues/66

我知道出了什么问题:在VPI的示例中,页面的样式在AndroidManifest.xml中设置(例如)

<activity
     android:name=".SampleTabsDefault"
     android:theme="@style/Theme.PageIndicatorDefaults"> 
</activity>
Run Code Online (Sandbox Code Playgroud)

但是当我将android:theme元素添加到我自己的Manifest.xml中时,我得到以下异常:

03-16 11:06:24.400: E/AndroidRuntime(483): Caused by: java.lang.IllegalStateException: You must use Theme.Sherlock, Theme.Sherlock.Light, Theme.Sherlock.Light.DarkActionBar, or a derivative.
Run Code Online (Sandbox Code Playgroud)

我还尝试将所有样式信息复制到styles.xml,但这也不起作用.

你能告诉我如何设置VPI的风格吗?谢谢!

编辑:现在我已经添加了

<activity
         android:name=".SampleTabsDefault"
         android:theme="@style/StyledIndicators"> 
</activity>
Run Code Online (Sandbox Code Playgroud)

到我的Manifest.xml

以及styles.xml中的以下样式

<style name="Theme.BataApp" parent="Theme.Sherlock.Light.DarkActionBar">
        <item name="actionBarStyle">@style/Widget.Styled.ActionBar</item>
        <item name="android:actionBarStyle">@style/Widget.Styled.ActionBar</item>
    </style>   

    <style name="StyledIndicators" parent="Theme.BataApp">
        <item name="vpiTitlePageIndicatorStyle">@style/Widget.TitlePageIndicator</item>
        <item name="vpiTabPageIndicatorStyle">@style/Widget.TabPageIndicator</item>
        <item name="vpiTabTextStyle">@style/Widget.TabPageIndicator.Text</item>
    </style>
Run Code Online (Sandbox Code Playgroud)

结果:我没有得到任何异常,看到样式,但我现在看不到任何碎片:(

活动代码可以在这里找到:http://pastebin.com/hsNgxFDZ 当前页面的风格截图:

IMG

Rei*_*ier 36

为了看到碎片,你必须以某种方式扩展Android基础主题.要查看ViewPagerIndicator,您必须以某种方式包含这些样式定义.答案是创建自己的主题,扩展ActionBarSherlock主题(扩展Android基础主题),并实现ViewPagerIndicator样式.

例:

<style name="myTheme" parent="@style/Theme.Sherlock">

    <!-- If you want to use the default ViewPagerIndicator-styles, use the following: -->
    <item name="vpiTitlePageIndicatorStyle">@style/Widget.TitlePageIndicator</item>
    <item name="vpiTabPageIndicatorStyle">@style/Widget.TabPageIndicator</item>
    <item name="vpiTabTextStyle">@style/Widget.TabPageIndicator.Text</item>

    <!-- If you want to implement your custom style of CirclePageIndicator, do it like so: -->
    <item name="vpiCirclePageIndicatorStyle">@style/myCirclePageIndicator</item>


    <!-- Put whatever other styles you want to define in your custom theme -->
</style>

<style name="myCirclePageIndicator" parent="Widget.CirclePageIndicator">
    <item name="fillColor">@color/my_custom_circle_indicator_fill_color</item>
</style>
Run Code Online (Sandbox Code Playgroud)

然后在你的Manifest中,设置android:theme="@style/myTheme"<application>或者你<activity>的.

请注意,您不必包含所有4个"vpi ..." - 样式; 你只需要包括你使用的那些.例如,如果您只使用CirclePageIndicator,则只需要包括<item name="vpiCirclePageIndicatorStyle">...</item>并且可以省略其他3项声明.

  • 在最新版本中没有`vpiTabTextStyle`,`android:textSize`和`android:textColor`被用作`TextAppearance.TabPageIndicator`样式的一部分. (4认同)

use*_*553 5

我在添加样式时意外删除了android:layout_weight ="1".

对于想要用ABS实现VPI的其他人:

layout.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">

    <com.viewpagerindicator.TabPageIndicator
        android:id="@+id/indicator"
        android:layout_height="wrap_content"
        android:layout_width="fill_parent"
        style="@style/StyledIndicators" />
    <android.support.v4.view.ViewPager
        android:id="@+id/pager"
        android:layout_width="fill_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        />
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)

styles.xml:

 <style name="Theme.BataApp" parent="Theme.Sherlock.Light.DarkActionBar">
            etc.
        </style>   

        <style name="StyledIndicators" parent="Theme.BataApp">
            <item name="vpiTitlePageIndicatorStyle">@style/Widget.TitlePageIndicator</item>
            <item name="vpiTabPageIndicatorStyle">@style/Widget.TabPageIndicator</item>
            <item name="vpiTabTextStyle">@style/Widget.TabPageIndicator.Text</item>
        </style>
Run Code Online (Sandbox Code Playgroud)

谢谢@Reinier!:d