
one.empty3.feature20220726.HoughTransformOutput Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of empty3-library-3d Show documentation
Show all versions of empty3-library-3d Show documentation
3D rendering engine. Plus modelling. Expected glsl textures 3d and 2d rendering3D primitives, and a lot of scenes' samples to test.+ Game Jogl reworked, Calculator (numbers and vectors). Java code parser implementation starts (<=1.2)
The newest version!
//package one.empty3.feature20220726;
//
//import javaAnd.awt.image.imageio.ImageIO;
//import javaAnd.awt.*;
//import javaAnd.awt.image.BufferedImage;
//import javaAnd.awt.image.Graphics2D;
//
//import java.awt.image.RescaleOp;
//import java.io.File;
//import java.io.IOException;
//import java.util.List;
//
//public class HoughTransformOutput {
//
// private static String path = System.getProperty("user.dir");
// static int drawnCircles = 1;
// static int imgWidth;
// static int imgHeight;
//
// public static void writeImage(int[][] imgArray, File outFile) throws Exception {
// BufferedImage img = new javaAnd.awt.image.BufferedImage(imgWidth, imgHeight, javaAnd.awt.image.BufferedImage.TYPE_INT_ARGB);
// for (int i = 0; i < imgWidth; i++) {
// for (int j = 0; j < imgHeight; j++) {
// img.setRGB(i, j, new Color(255, 255, 255, imgArray[i][j]).getRGB());
// }
// }
// ImageIO.write(img, "png", outFile);
// }
//
// public static void writeImage(double[][] imgArray, File outFile) throws Exception {
// BufferedImage img = new javaAnd.awt.image.BufferedImage(imgWidth, imgHeight, javaAnd.awt.image.BufferedImage.TYPE_BYTE_GRAY);
// for (int i = 0; i < imgWidth; i++) {
// for (int j = 0; j < imgHeight; j++) {
// img.setRGB(i, j, (int) imgArray[i][j]);
// }
// }
// ImageIO.write(img, "png", outFile);
// }
//
// public static void writeImage(BufferedImage image, File outFile) throws Exception {
// ImageIO.write(image, "png", outFile);
// }
//
// public static void writeImage(double[][] sobelArray, File outFile, int threshold) throws Exception {
// BufferedImage img = new javaAnd.awt.image.BufferedImage(imgWidth, imgHeight, javaAnd.awt.image.BufferedImage.TYPE_BYTE_GRAY);
// for (int i = 0; i < imgWidth; i++) {
// for (int j = 0; j < imgHeight; j++) {
// if (sobelArray[i][j] > threshold) {
// img.setRGB(i, j, Color.WHITE.getRGB());
// }
// }
// }
// ImageIO.write(img, "png", outFile);
// }
//
// public static void superimposeCircles(List hits, javaAnd.awt.image.BufferedImage in, File out) {
// Graphics2D g = in.createGraphics();
// g.setColor(Color.RED);
// for (int circles = 0; circles < drawnCircles; circles++) {
// CircleHit toDraw = hits.get(circles);
// double a = toDraw.x - toDraw.r * Math.cos(0 * Math.PI / 180);
// double b = toDraw.y - toDraw.r * Math.sin(90 * Math.PI / 180);
// g.drawOval((int) a, (int) b, 2 * toDraw.r, 2 * toDraw.r);
// if (circles < 10) {
// System.out.printf("Circle #%d\n", circles);
// System.out.printf("X: %d\n", toDraw.x);
// System.out.printf("Y: %d\n", toDraw.y);
// System.out.printf("R: %d\n", toDraw.r);
// }
// }
// try {
// ImageIO.write(in, "jpg", out);
// } catch (IOException e) {
// e.printStackTrace();
// }
//
// }
///*
// public static void superimposeCircles(List hits, double[][] sobelTotal, File out) throws Exception {
// BufferedImage totalCircles = new javaAnd.awt.image.BufferedImage(imgWidth, imgHeight, javaAnd.awt.image.BufferedImage.TYPE_INT_ARGB);
//
// BufferedImage total = changeBrightness(0.5f, scaledSobelResult(sobelTotal));
// totalCircles.getGraphics().drawImage(total, 0, 0);
// Graphics2D g = totalCircles.createGraphics();
// g.setColor(Color.RED);
// for (int circles = 0; circles < drawnCircles; circles++) {
// CircleHit toDraw = hits.get(circles);
// double a = toDraw.x - toDraw.r * Math.cos(0 * Math.PI / 180);
// double b = toDraw.y - toDraw.r * Math.sin(90 * Math.PI / 180);
// g.drawOval((int) a, (int) b, 2 * toDraw.r, 2 * toDraw.r);
// if (circles < 10) {
// System.out.printf("Circle #%d\n", circles);
// System.out.printf("X: %d\n", toDraw.x);
// System.out.printf("Y: %d\n", toDraw.y);
// System.out.printf("R: %d\n", toDraw.r);
// }
// }
//
// ImageIO.write(totalCircles, "png", out);
// }
///*/
// public static javaAnd.awt.image.BufferedImage scaledSobelResult(double[][] sobelTotal) {
// BufferedImage total = new javaAnd.awt.image.BufferedImage(imgWidth, imgHeight, javaAnd.awt.image.BufferedImage.TYPE_BYTE_GRAY);
// double max = 0;
// for (int i = 0; i < imgWidth; i++) {
// for (int j = 0; j < imgHeight; j++) {
// if (sobelTotal[i][j] > max) {
// max = sobelTotal[i][j];
// }
// }
// }
// for (int i = 0; i < imgWidth; i++) {
// for (int j = 0; j < imgHeight; j++) {
// //maps every pixel to a grayscale value between 0 and 255 from between 0 and the max value in sobelTotal
// int rgb = new Color((int) map(sobelTotal[i][j], 0, max, 0, 255),
// (int) map(sobelTotal[i][j], 0, max, 0, 255),
// (int) map(sobelTotal[i][j], 0, max, 0, 255), 255).getRGB();
// total.setRGB(i, j, rgb);
// }
// }
// return changeBrightness(20.0f, total);
// }
//
// //maps the given value between startCoord1 and endCoord1 to a value between startCoord2 and endCoord2
// public static double map(double valueCoord1,
// double startCoord1, double endCoord1,
// double startCoord2, double endCoord2) {
//
//
// double ratio = (endCoord2 - startCoord2) / (endCoord1 - startCoord1);
// return ratio * (valueCoord1 - startCoord1) + startCoord2;
// }
//
//
// //changes the brightness of an image by the factor given
// private static javaAnd.awt.image.BufferedImage changeBrightness(float brightenFactor, javaAnd.awt.image.BufferedImage image) {
// RescaleOp op = new RescaleOp(brightenFactor, 0, null);
// image = op.filter(image, image);
// return image;
// }
//}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy