Programa Java para implementar la API RenderingHints

El atributo de gráficos utilizado por la clase Graphics2D es java.awt.RenderingHints . Esta clase es una asignación (un java.util.Map) de un conjunto de nombres de sugerencias de representación a un conjunto de valores de sugerencias de representación. A diferencia de otros atributos, Graphics2D define más de un método para establecer el atributo de sugerencias de representación.

  • setRenderingHints() especifica un nuevo conjunto de sugerencias que reemplaza el antiguo conjunto de sugerencias.
  • addRenderingHints() agrega un conjunto de sugerencias al conjunto existente.
  • setRenderingHint() establece el valor de una sola sugerencia en el conjunto actual de sugerencias.

Las sugerencias de renderizado son sugerencias para Java 2D sobre cómo debe realizar su renderizado. 

La clase RenderingHintsdefine un número de constantes cuyos nombres comienzan con KEY_. Estas constantes representan el tipo de sugerencias que puede dar. La clase también define una serie de constantes cuyos nombres comienzan con VALUE_. Estos son los valores legales para las distintas pistas. Los nombres de las constantes VALUE dejan en claro con qué constante KEY indirecta está asociado cada valor. El propósito de las sugerencias es permitirle solicitar que Java 2D active o desactive una característica particular, como el antialiasing. Además, las sugerencias le permiten sugerir qué tipo de compensación entre velocidad y calidad debería hacer Java 2D. Recuerde que estos son consejos y sugerencias para Java 2D, no comandos. No todas las implementaciones de Java 2D admiten todas las sugerencias, y las diferentes implementaciones tienen diferentes valores predeterminados para las sugerencias. Además, los significados de las sugerencias no están definidos con precisión,

La clase RenderingHints define y administra colecciones de claves y valores asociados que permiten que una aplicación proporcione información sobre la elección de algoritmos utilizados por otras clases que realizan servicios de procesamiento y manipulación de imágenes.

Implementación:

Java

// Java Program to show the demonstration to 
// Implement RenderingHints API
  
import java.awt.RenderingHints;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
  
public class RenderingHintsImpl
{
    private RenderingHints renderingHints;
  
    // Constructs a new object with keys and values
    // initialized from the
    // specified Map object which may be null.
  
    public RenderingHintsImpl(Map<RenderingHints.Key, ?> init)
    {
        renderingHints = new RenderingHints(init);
    }
    
     // Constructs a new object with the specified key/value
     // pair. 
    public RenderingHintsImpl(RenderingHints.Key key,
                              Object value)
    {
        renderingHints = new RenderingHints(key, value);
    }
  
     // Adds all of the keys and corresponding values from
     // the specified
     // RenderingHints object to this RenderingHints object.
    public void add(RenderingHints hints)
    {
        renderingHints.add(hints);
    }
    
     // Clears this RenderingHints object of all key/value
     // pairs. 
    public void clear() { renderingHints.clear(); }
  
     // Creates a clone of this RenderingHints object that
     // has the same contents
     // as this RenderingHints object.
    
    public Object clone() { return renderingHints.clone(); }
  
     // Returns true if this RenderingHints contains a
     // mapping for the specified key. 
  
    public boolean containsKey(Object key)
    {
        return renderingHints.containsKey(key);
    }
  
     // Returns true if this RenderingHints maps one or more
     // keys to the specified value. 
    public boolean containsValue(Object value)
    {
        return renderingHints.containsValue(value);
    }
  
     // Returns a Set view of the mappings contained in this
     // RenderingHints
    public Set<Map.Entry<Object, Object> > entrySet()
    {
        return renderingHints.entrySet();
    }
  
     // Returns the value to which the specified key is
     // mapped. 
    public Object get(Object key)
    {
        return renderingHints.get(key);
    }
  
     // Returns true if this RenderingHints contains no
     // key-value mappings. 
    public boolean isEmpty()
    {
        return renderingHints.isEmpty();
    }
  
     // Returns a Set view of the Keys contained in this
     // RenderingHints. 
    public Set<Object> keySet()
    {
       return renderingHints.keySet();
    }
  
     // Maps the specified key to the specified value in
     // this RenderingHints object. 
    public Object put(Object key, Object value)
    {
        return renderingHints.put(key, value);
    }
  
     // Copies all of the mappings from the specified Map to
     // this RenderingHints. 
    public void putAll(Map<?, ?> m)
    {
        renderingHints.putAll(m);
    }
   
     // Removes the key and its corresponding value from
     // this RenderingHints object. 
    public Object remove(Object key)
    {
        return renderingHints.remove(key);
    }
    
     // Returns the number of key-value mappings in this
     // RenderingHints. 
    public int size() { return renderingHints.size(); }
  
     // Returns a Collection view of the values contained in
     // this RenderinHints. 
    public Collection<Object> values()
    {
        return renderingHints.values();
    }
  
    public static void main(String[] arg)
    {
  
        RenderingHintsImpl renderingHints  = new RenderingHintsImpl(
                RenderingHints.KEY_ALPHA_INTERPOLATION,
  
        RenderingHints.VALUE_ALPHA_INTERPOLATION_QUALITY);
  
        renderingHints.put(
            RenderingHints.KEY_TEXT_ANTIALIASING,
            RenderingHints.VALUE_TEXT_ANTIALIAS_ON);
  
        renderingHints.put(
            RenderingHints.KEY_FRACTIONALMETRICS,
            RenderingHints.VALUE_FRACTIONALMETRICS_ON);
  
        renderingHints.put(
            RenderingHints.KEY_COLOR_RENDERING,
            RenderingHints.VALUE_COLOR_RENDER_QUALITY);
  
        Map<Object, Object> anotherMap = new HashMap<Object, Object>();
  
        anotherMap.put(RenderingHints.KEY_STROKE_CONTROL,
                       RenderingHints.VALUE_STROKE_PURE);
  
        anotherMap.put(RenderingHints.KEY_DITHERING,
                       RenderingHints.VALUE_DITHER_ENABLE);
  
        renderingHints.putAll(anotherMap);
  
        System.out.println("the key set of the renderingHints is - ");
  
        Set<Object> keySet = renderingHints.keySet();
  
        Iterator<Object> itr = keySet.iterator();
  
        while (itr.hasNext())
        {
            System.out.println(itr.next());
        }
  
        System.out.println();
  
        System.out.println("the values of the renderingHints is -");
  
        Collection<Object> collectionValues = renderingHints.values();
  
        itr = collectionValues.iterator();
  
        while (itr.hasNext())
        {
            System.out.println(itr.next());
        }
  
        System.out.println();
  
        System.out.println("the entry set of the renderingHints is -");
  
        Iterator<Entry<Object, Object> > eitr;
  
        Set<Entry<Object, Object> > entrySet = renderingHints.entrySet();
  
        eitr = entrySet.iterator();
  
        while (eitr.hasNext())
        {
            System.out.println(eitr.next());
        }
  
        System.out.println(
            "the renderingHints contains Key  KEY_TEXT_ANTIALIASING :"
            + renderingHints.containsKey(RenderingHints.KEY_TEXT_ANTIALIASING));
  
        System.out.println(
            "the renderingHints contains Value VALUE_TEXT_ANTIALIAS_ON :"
            + renderingHints.containsValue(
                RenderingHints.VALUE_TEXT_ANTIALIAS_ON));
  
        System.out.println("the size of the renderingHints is :"
            + renderingHints.size());
  
        renderingHints.clear();
  
        if (renderingHints.isEmpty())
  
           System.out.println("The renderingHints is empty");
  
        else
  
           System.out.println("The renderingHints is not empty");
    }
}
Producción

the key set of the renderingHints is - 
Alpha blending interpolation method key
Fractional metrics enable key
Stroke normalization control key
Color rendering quality key
Dithering quality key
Text-specific antialiasing enable key

the values of the renderingHints is -
Highest quality alpha blending methods
Fractional text metrics mode
Pure stroke conversion for accurate paths
Highest quality color rendering mode
Dithered rendering mode
Antialiased text mode

the entry set of the renderingHints is -
Alpha blending interpolation method key=Highest quality alpha blending methods
Fractional metrics enable key=Fractional text metrics mode
Stroke normalization control key=Pure stroke conversion for accurate paths
Color rendering quality key=Highest quality color rendering mode
Dithering quality key=Dithered rendering mode
Text-specific antialiasing enable key=Antialiased text mode
the renderingHints contains Key  KEY_TEXT_ANTIALIASING :true
the renderingHints contains Value VALUE_TEXT_ANTIALIAS_ON :true
the size of the renderingHints is :6
The renderingHints is empty

Publicación traducida automáticamente

Artículo escrito por edm17b015 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *