Renders multiple paragraphs of text in an array to an image (created and returned). : BufferedImage « 2D Graphics GUI « Java






Renders multiple paragraphs of text in an array to an image (created and returned).

    
/*
 *
 * Created on March 16, 2007, 4:34 PM
 *
 * Copyright 2006-2007 Nigel Hughes
 *
 * 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.
 */

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.GraphicsConfiguration;
import java.awt.GraphicsEnvironment;
import java.awt.RenderingHints;
import java.awt.Transparency;
import java.awt.font.FontRenderContext;
import java.awt.font.LineBreakMeasurer;
import java.awt.font.TextAttribute;
import java.awt.font.TextLayout;
import java.awt.image.BufferedImage;
import java.text.AttributedCharacterIterator;
import java.text.AttributedString;
import java.util.Hashtable;
import java.util.LinkedList;
/**

 * @author nigel
 */
public class Utils {
  /** 
   * Renders multiple paragraphs of text in an array to an image (created and returned). 
   *
   * @param font The font to use
   * @param textColor The color of the text
   * @param text The message in an array of strings (one paragraph in each
   * @param width The width the text should be limited to
   * @return An image with the text rendered into it
   */
  public static BufferedImage renderTextToImage(Font font, Color textColor, String text[], int width){
      LinkedList<BufferedImage> images = new LinkedList<BufferedImage>();
      
      int totalHeight = 0;
      
      for (String paragraph : text){
          BufferedImage paraImage = renderTextToImage(font,textColor,paragraph,width);
          totalHeight+=paraImage.getHeight();
          images.add(paraImage);
      }
      
      BufferedImage image = createCompatibleImage(width,totalHeight);
      Graphics2D graphics = (Graphics2D) image.createGraphics();
      
      int y=0;
      
      for (BufferedImage paraImage : images){
          graphics.drawImage(paraImage,0,y,null);
          y+=paraImage.getHeight();
      }
      
      graphics.dispose();
      return image;
  }
  /** 
   * Renders a paragraph of text (line breaks ignored) to an image (created and returned). 
   *
   * @param font The font to use
   * @param textColor The color of the text
   * @param text The message
   * @param width The width the text should be limited to
   * @return An image with the text rendered into it
   */
  public static BufferedImage renderTextToImage(Font font, Color textColor, String text, int width){
      Hashtable   map = new Hashtable();
      map.put(TextAttribute.FONT, font);
      AttributedString attributedString = new AttributedString(text,map);
      AttributedCharacterIterator paragraph = attributedString.getIterator();
      
      FontRenderContext frc = new FontRenderContext(null, false, false);
      int paragraphStart = paragraph.getBeginIndex();
      int paragraphEnd = paragraph.getEndIndex();
      LineBreakMeasurer lineMeasurer = new LineBreakMeasurer(paragraph, frc);      
      
      float   drawPosY=0;
      
      //First time around, just determine the height
      while (lineMeasurer.getPosition() < paragraphEnd) {
          TextLayout layout = lineMeasurer.nextLayout(width);
          
          // Move it down
          drawPosY += layout.getAscent() + layout.getDescent() + layout.getLeading();
      }
      
      BufferedImage image = createCompatibleImage(width,(int) drawPosY);
      Graphics2D graphics = (Graphics2D) image.getGraphics();
      graphics.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_ON);
      
      drawPosY=0;
      lineMeasurer.setPosition(paragraphStart);
      while (lineMeasurer.getPosition() < paragraphEnd) {
          TextLayout layout = lineMeasurer.nextLayout(width);
          
          // Move y-coordinate by the ascent of the layout.
          drawPosY += layout.getAscent();
          
         /* Compute pen x position.  If the paragraph is
            right-to-left, we want to align the TextLayouts
            to the right edge of the panel.
          */
          float drawPosX;
          if (layout.isLeftToRight()) {
              drawPosX = 0;
          } else {
              drawPosX = width - layout.getAdvance();
          }
          
          // Draw the TextLayout at (drawPosX, drawPosY).
          layout.draw(graphics, drawPosX, drawPosY);
          
          // Move y-coordinate in preparation for next layout.
          drawPosY += layout.getDescent() + layout.getLeading();
      }
      
      graphics.dispose();
      return image;
  }
  /**
   * Creates an image compatible with the current display
   * 
   * @return A BufferedImage with the appropriate color model
   */
  public static BufferedImage createCompatibleImage(int width, int height) {
    GraphicsConfiguration configuration = GraphicsEnvironment.getLocalGraphicsEnvironment()
        .getDefaultScreenDevice().getDefaultConfiguration();
    return configuration.createCompatibleImage(width, height, Transparency.TRANSLUCENT);
  }
}

   
    
    
    
  








Related examples in the same category

1.BufferImage based Label
2.Animated clipping of an image and shapes with alphaAnimated clipping of an image and shapes with alpha
3.Renders an ellipse overlapping a rectangle with the compositing rule and alpha value selected by the userRenders an ellipse overlapping a rectangle with the compositing rule and alpha value selected by the user
4.Image operationsImage operations
5.BufferedImage with Jumbled images
6.Save an image after operations
7.Create buffered image that does not support transparency
8.Create a buffered image that supports transparency
9.Display image after operation
10.Compositing is the combining of elements from separate sources into single images
11.Convert a non-RGB image to an RGB buffered image
12.Blurring a Buffered Image
13.Sharpening a Buffered Image
14.Converting a Colored Buffered Image to Gray
15.Get average of a set of images with WritableRaster
16.Creating a BufferedImage from an Image object
17.Create Headless BufferedImage
18.Constructs a BufferedImage with a linear sRGB colorModel, and alpha
19.Creates and returns a buffered version of the specified image.
20.Scale, convert images
21.Make Linear Buffered Image
22.Create and Draw BufferedImage
23.Draw centered BufferedImage
24.Desaturate BufferedImage
25.Convert Image to BufferedImage
26.Converts an Image to a BufferedImage
27.store BufferedImage to file
28.store BufferedImage to file and then retrieve to BufferedImage
29.Returns a BufferedImage with the specified image type, where the graphical content is a copy of the specified image.
30.Draw code point