All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.android.resources.Density Maven / Gradle / Ivy

There is a newer version: 25.3.0
Show newest version
/*
 * Copyright (C) 2010 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 com.android.resources;


import java.util.EnumSet;
import java.util.Set;

/**
 * Density enum.
 * 

This is used in the manifest in the uses-configuration node and in the resource folder names * as well as other places needing to know the density values. */ public enum Density implements ResourceEnum { XXXHIGH("xxxhdpi", "XXX-High Density", 640, 18), //$NON-NLS-1$ DPI_560("560dpi", "560 DPI Density", 560, 1), //$NON-NLS-1$ XXHIGH( "xxhdpi", "XX-High Density", 480, 16), //$NON-NLS-1$ DPI_420("420dpi", "420 DPI Density", 420, 23), //$NON-NLS-1$ DPI_400("400dpi", "400 DPI Density", 400, 1), //$NON-NLS-1$ DPI_360("360dpi", "360 DPI Density", 360, 23), //$NON-NLS-1$ XHIGH( "xhdpi", "X-High Density", 320, 8), //$NON-NLS-1$ DPI_280("280dpi", "280 DPI Density", 280, 22), //$NON-NLS-1$ HIGH( "hdpi", "High Density", 240, 4), //$NON-NLS-1$ TV( "tvdpi", "TV Density", 213, 13), //$NON-NLS-1$ MEDIUM( "mdpi", "Medium Density", 160, 4), //$NON-NLS-1$ LOW( "ldpi", "Low Density", 120, 4), //$NON-NLS-1$ ANYDPI( "anydpi", "Any Density", 0, 21), //$NON-NLS-1$ NODPI( "nodpi", "No Density", 0, 4); //$NON-NLS-1$ public static final int DEFAULT_DENSITY = 160; private final String mValue; private final String mDisplayValue; private final int mDensity; private final int mSince; Density(String value, String displayValue, int density, int since) { mValue = value; mDisplayValue = displayValue; mDensity = density; mSince = since; } /** * Returns the enum matching the provided qualifier value. * @param value The qualifier value. * @return the enum for the qualifier value or null if no match was found. */ public static Density getEnum(String value) { for (Density orient : values()) { if (orient.mValue.equals(value)) { return orient; } } return null; } /** * Returns the enum matching the given density value * @param value The density value. * @return the enum for the density value or null if no match was found. */ public static Density getEnum(int value) { for (Density d : values()) { if (d.mDensity == value) { return d; } } return null; } @Override public String getResourceValue() { return mValue; } public int getDpiValue() { return mDensity; } public int since() { return mSince; } public String getLegacyValue() { if (this != NODPI && this != ANYDPI) { return String.format("%1$ddpi", getDpiValue()); } return ""; } @Override public String getShortDisplayValue() { return mDisplayValue; } @Override public String getLongDisplayValue() { return mDisplayValue; } public static int getIndex(Density value) { return value == null ? -1 : value.ordinal(); } public static Density getByIndex(int index) { Density[] values = values(); if (index >=0 && index < values.length) { return values[index]; } return null; } /** * Returns all densities which are recommended and valid for a device. * * @see #isRecommended() * @see #isValidValueForDevice() */ public static Set getRecommendedValuesForDevice() { EnumSet result = EnumSet.allOf(Density.class); for (Density value : values()) { if (!value.isRecommended() || !value.isValidValueForDevice()) { result.remove(value); } } return result; } /** * Returns true if this density is relevant for app developers (e.g. * a density you should consider providing resources for) */ public boolean isRecommended() { switch (this) { case TV: case DPI_280: case DPI_360: case DPI_400: case DPI_420: case DPI_560: return false; default: return true; } } @Override public boolean isFakeValue() { return false; } @Override public boolean isValidValueForDevice() { return this != NODPI && this != ANYDPI; // nodpi/anydpi is not a valid config for devices. } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy