Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* Copyright (c) 2005-2019 Radiance Kirill Grouchnikov. All Rights Reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* o Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* o Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* o Neither the name of the copyright holder nor the names of
* its contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.pushingpixels.substance.api.watermark;
import org.pushingpixels.neon.NeonCortex;
import org.pushingpixels.substance.api.SubstanceSkin;
import org.pushingpixels.substance.api.colorscheme.SubstanceColorScheme;
import org.pushingpixels.substance.internal.utils.SubstanceCoreUtilities;
import java.awt.*;
import java.awt.geom.Line2D;
import java.awt.image.BufferedImage;
/**
* Simple implementation of
* {@link org.pushingpixels.substance.api.watermark.SubstanceWatermark}, drawing darker
* even lines as watermark. This is the default watermark implementation. This
* class is part of officially supported API.
*
* @author Kirill Grouchnikov
* @author Chris Hall
*/
public class SubstanceStripeWatermark implements SubstanceWatermark {
/**
* Watermark image (screen-sized).
*/
private static BufferedImage watermarkImage = null;
@Override
public void drawWatermarkImage(Graphics graphics, Component c, int x,
int y, int width, int height) {
if (!c.isShowing())
return;
int dx = c.getLocationOnScreen().x;
int dy = c.getLocationOnScreen().y;
NeonCortex.drawImage(graphics, SubstanceStripeWatermark.watermarkImage, x, y, width,
height, dx, dy);
}
@Override
public boolean updateWatermarkImage(SubstanceSkin skin) {
// fix by Chris for bug 67 - support for multiple screens
Rectangle virtualBounds = new Rectangle();
GraphicsEnvironment ge = GraphicsEnvironment
.getLocalGraphicsEnvironment();
GraphicsDevice[] gds = ge.getScreenDevices();
for (GraphicsDevice gd : gds) {
GraphicsConfiguration gc = gd.getDefaultConfiguration();
virtualBounds = virtualBounds.union(gc.getBounds());
}
int screenWidth = virtualBounds.width;
int screenHeight = virtualBounds.height;
SubstanceStripeWatermark.watermarkImage = SubstanceCoreUtilities
.getBlankImage(screenWidth, screenHeight);
Graphics2D graphics = SubstanceStripeWatermark.watermarkImage.createGraphics();
boolean status = this.drawWatermarkImage(skin, graphics, 0, 0,
screenWidth, screenHeight, false);
graphics.dispose();
return status;
}
@Override
public void previewWatermark(Graphics g, SubstanceSkin skin, int x, int y,
int width, int height) {
this.drawWatermarkImage(skin, (Graphics2D) g, x, y, width, height, true);
}
/**
* Draws the specified portion of the watermark image.
*
* @param skin
* Skin to use for painting the watermark.
* @param graphics
* Graphic context.
* @param x
* the x coordinate of the watermark to be drawn.
* @param y
* The y coordinate of the watermark to be drawn.
* @param width
* The width of the watermark to be drawn.
* @param height
* The height of the watermark to be drawn.
* @param isPreview
* Indication whether the result is a preview image.
* @return Indication whether the draw succeeded.
*/
private boolean drawWatermarkImage(SubstanceSkin skin, Graphics2D graphics,
int x, int y, int width, int height, boolean isPreview) {
Color stampColor = null;
SubstanceColorScheme scheme = skin.getWatermarkColorScheme();
if (isPreview)
stampColor = scheme.isDark() ? Color.lightGray : Color.darkGray;
else {
stampColor = scheme.getWatermarkStampColor();
}
double scaleFactor = NeonCortex.getScaleFactor();
double borderStrokeWidth = 1.0f / scaleFactor;
graphics.setColor(stampColor);
graphics.setStroke(new BasicStroke(1.0f / (float) scaleFactor,
BasicStroke.CAP_BUTT, BasicStroke.JOIN_ROUND));
double row = y;
while (row < (y + height)) {
graphics.draw(new Line2D.Double(x, row, x + width, row));
row += 2 * borderStrokeWidth;
}
if (isPreview) {
graphics.setColor(Color.gray);
row = y + 1;
while (row < (y + height)) {
graphics.draw(new Line2D.Double(x, row, x + width, row));
row += 2 * borderStrokeWidth;
}
}
return true;
}
@Override
public String getDisplayName() {
return "Stripes";
}
@Override
public void dispose() {
watermarkImage = null;
}
}