| /* |
| * Copyright (C) 2014 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package android.support.v7.internal.view; |
| |
| import android.content.Context; |
| import android.content.ContextWrapper; |
| import android.content.res.Resources; |
| import android.support.annotation.StyleRes; |
| import android.support.v7.appcompat.R; |
| import android.view.LayoutInflater; |
| |
| /** |
| * A ContextWrapper that allows you to modify the theme from what is in the |
| * wrapped context. |
| * |
| * @hide |
| */ |
| public class ContextThemeWrapper extends ContextWrapper { |
| private int mThemeResource; |
| private Resources.Theme mTheme; |
| private LayoutInflater mInflater; |
| |
| public ContextThemeWrapper(Context base, @StyleRes int themeResId) { |
| super(base); |
| mThemeResource = themeResId; |
| } |
| |
| public ContextThemeWrapper(Context base, Resources.Theme theme) { |
| super(base); |
| mTheme = theme; |
| } |
| |
| @Override |
| public void setTheme(int resid) { |
| if (mThemeResource != resid) { |
| mThemeResource = resid; |
| initializeTheme(); |
| } |
| } |
| |
| public int getThemeResId() { |
| return mThemeResource; |
| } |
| |
| @Override |
| public Resources.Theme getTheme() { |
| if (mTheme != null) { |
| return mTheme; |
| } |
| |
| if (mThemeResource == 0) { |
| mThemeResource = R.style.Theme_AppCompat_Light; |
| } |
| initializeTheme(); |
| |
| return mTheme; |
| } |
| |
| @Override |
| public Object getSystemService(String name) { |
| if (LAYOUT_INFLATER_SERVICE.equals(name)) { |
| if (mInflater == null) { |
| mInflater = LayoutInflater.from(getBaseContext()).cloneInContext(this); |
| } |
| return mInflater; |
| } |
| return getBaseContext().getSystemService(name); |
| } |
| |
| /** |
| * Called by {@link #setTheme} and {@link #getTheme} to apply a theme |
| * resource to the current Theme object. Can override to change the |
| * default (simple) behavior. This method will not be called in multiple |
| * threads simultaneously. |
| * |
| * @param theme The Theme object being modified. |
| * @param resid The theme style resource being applied to <var>theme</var>. |
| * @param first Set to true if this is the first time a style is being |
| * applied to <var>theme</var>. |
| */ |
| protected void onApplyThemeResource(Resources.Theme theme, int resid, boolean first) { |
| theme.applyStyle(resid, true); |
| } |
| |
| private void initializeTheme() { |
| final boolean first = mTheme == null; |
| if (first) { |
| mTheme = getResources().newTheme(); |
| Resources.Theme theme = getBaseContext().getTheme(); |
| if (theme != null) { |
| mTheme.setTo(theme); |
| } |
| } |
| onApplyThemeResource(mTheme, mThemeResource, first); |
| } |
| } |
| |