Back to project page elementary.
The source code is released under:
MIT License
If you think the Android project elementary listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.
/* * The MIT License (MIT)// w ww . ja v a 2 s. c o m * Copyright 2012 Steve Guidetti * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the Software??), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED AS IS??, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ package com.ultramegatech.ey.util; import android.content.Context; import android.content.SharedPreferences; import android.content.res.Resources; import android.preference.PreferenceManager; import com.ultramegatech.ey.R; import java.util.HashMap; import java.util.LinkedHashMap; /** * Utility class for common methods relating to chemical elements. * * @author Steve Guidetti */ public class ElementUtils { private Context mContext; /* Map of values to colors */ private HashMap<Object, Integer> mColorMap; /** * Constructor * * @param context */ public ElementUtils(Context context) { mContext = context; } /** * Get the element color based on the category name. * * @param context * @param key The category name * @return Color hex value */ public int getElementColor(String key) { if(mColorMap == null) { mColorMap = getColorMap(mContext); } return mColorMap.get(key); } /** * Load the element color map from array resources. * * @param context * @return */ public static HashMap<Object, Integer> getColorMap(Context context) { final HashMap<Object, Integer> colorMap = new LinkedHashMap<Object, Integer>(); final SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context); final String colorKey = prefs.getString("elementColors", "category"); final int keyArray; final int colorArray; if(colorKey.equals("block")) { keyArray = R.array.ptBlocks; colorArray = R.array.ptBlockColors; } else { keyArray = R.array.ptCategories; colorArray = R.array.ptCategoryColors; } final Resources res = context.getResources(); final String[] colorKeys = res.getStringArray(keyArray); final int[] colorValues = res.getIntArray(colorArray); if(colorKeys != null && colorValues != null && colorValues.length >= colorKeys.length) { for(int i = 0; i < colorKeys.length; i++) { colorMap.put(colorKeys[i], colorValues[i]); } } return colorMap; } }