/*
* Copyright (C) 2012 The CyanogenMod 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 com.cyanogenmod.filemanager.ui.preferences;
import android.content.Context;
import android.util.AttributeSet;
import android.widget.ImageView;
import android.widget.RelativeLayout;
import android.widget.TextView;
import com.cyanogenmod.filemanager.R;
import com.cyanogenmod.filemanager.ui.ThemeManager;
import com.cyanogenmod.filemanager.ui.ThemeManager.Theme;
/**
* A view that display information about a {@link Theme}
*/
public class ThemeView extends RelativeLayout {
private TextView mName;
private TextView mAuthor;
private TextView mDescription;
private ImageView mPreview;
/**
* Constructor of <code>ThemeView</code>.
*
* @param context The current context
*/
public ThemeView(Context context) {
super(context);
}
/**
* Constructor of <code>ThemeView</code>.
*
* @param context The current context
* @param attrs The attributes of the XML tag that is inflating the view.
*/
public ThemeView(Context context, AttributeSet attrs) {
super(context, attrs);
}
/**
* Constructor of <code>ThemeView</code>.
*
* @param context The current context
* @param attrs The attributes of the XML tag that is inflating the view.
* @param defStyle The default style to apply to this view. If 0, no style
* will be applied (beyond what is included in the theme). This may
* either be an attribute resource, whose value will be retrieved
* from the current theme, or an explicit style resource.
*/
public ThemeView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
/**
* {@inheritDoc}
*/
@Override
protected void onLayout(boolean changed, int l, int t, int r, int b) {
super.onLayout(changed, l, t, r, b);
this.mName = (TextView)findViewById(R.id.theme_name);
this.mAuthor = (TextView)findViewById(R.id.theme_author);
this.mDescription = (TextView)findViewById(R.id.theme_desc);
this.mPreview = (ImageView)findViewById(R.id.theme_preview);
// Apply current theme
Theme theme = ThemeManager.getCurrentTheme(getContext());
theme.setTextColor(getContext(), this.mName, "text_color"); //$NON-NLS-1$
theme.setTextColor(getContext(), this.mAuthor, "text_color"); //$NON-NLS-1$
theme.setTextColor(getContext(), this.mDescription, "text_color"); //$NON-NLS-1$
}
/**
* Method that return the view for the name of the theme
*
* @return TextView The view that holds the name of the theme
*/
public TextView getName() {
return this.mName;
}
/**
* Method that return the view for the author of the theme
*
* @return TextView The view that holds the author of the theme
*/
public TextView getAuthor() {
return this.mAuthor;
}
/**
* Method that return the view for the description of the theme
*
* @return TextView The view that holds the description of the theme
*/
public TextView getDescription() {
return this.mDescription;
}
/**
* Method that return the view for the preview image of the theme
*
* @return TextView The view that holds the preview image of the theme
*/
public ImageView getPreview() {
return this.mPreview;
}
}