-1

PagerTabStrip をアイコン付きで実装すると、正常に動作します。しかし、タブを変更すると、現在のタブアイコンが選択された画像を変更する必要があります。

私のコードの下

私の描画可能なアイコンセレクターコード

<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/ic_home_selected" android:state_selected="true" />
<item android:drawable="@drawable/ic_home_normal" android:state_selected="false" />
<item android:drawable="@drawable/ic_home_normal" />
</selector>

MainActivity.java

    viewPager = (ViewPager) findViewById(R.id.pager);
    tabs = (PagerTabStrip) findViewById(R.id.tabs);
    fragments = new ArrayList<>();
    fragments.add(R.drawable.menu_home_bg);
    fragments.add(R.drawable.menu_likes_bg);
    fragments.add(R.drawable.menu_matches_bg);
    fragments.add(R.drawable.menu_home_bg);
    pageAdapter = new TabPagerAdapter(getApplicationContext(), getSupportFragmentManager(), fragments);
    viewPager.setAdapter(pageAdapter);

アダプター クラスにアイコンを追加する

    Drawable image;
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
        image = context.getResources().getDrawable(tabIcon.get(position), context.getTheme());
    } else
        image = context.getResources().getDrawable(tabIcon.get(position));
    if (image != null)
        image.setBounds(0, 0, image.getIntrinsicWidth(), image.getIntrinsicHeight());
    SpannableStringBuilder sb = new SpannableStringBuilder(" ");
    ImageSpan imageSpan = new ImageSpan(image, ImageSpan.ALIGN_BOTTOM);
    sb.setSpan(imageSpan, 0, 1, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
    return sb;

タブの変更時にセレクターアイコンを変更する方法を教えてください

4

1 に答える 1

1

Webview 内でこのパスを参照することはできません。css ファイルを assets フォルダーに保存し、動的に参照する必要がある可能性があります。

CSS を assets フォルダーに配置し、HTML で操作を行いますが、相対パスで CSS を参照し、loadDataWithBaseURL() メソッドで HTML を WebView に読み込みます。

webView.loadDataWithBaseURL("file:///android_asset/", htmlString, "text/html", "utf-8", null);
E.g. you have styles.css file, put it to assets folder, create HTML and load it:

StringBuilder sb = new StringBuilder();
sb.append("<HTML><HEAD><LINK href=\"styles.css\" type=\"text/css\" rel=\"stylesheet\"/></HEAD><body>");
sb.append(tables.toString());
sb.append("</body></HTML>");
webView.loadDataWithBaseURL("file:///android_asset/", sb.toString(), "text/html","utf-8", null); 
于 2014-12-23T13:42:45.277 に答える