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

one.empty3.feature.pio.DiffE3 Maven / Gradle / Ivy

/*
 * Copyright (c) 2022-2023. Manuel Daniel Dahmen
 *
 *
 *    Copyright 2012-2023 Manuel Daniel Dahmen
 *
 *    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.
 */

/*
comparaipar cerlcle d intensite et
de lumierrs filtrers.
*/

package one.empty3.feature.pio;

import one.empty3.feature.PixM;
import one.empty3.io.ProcessFile;
import one.empty3.library.*;
import one.empty3.library.shader.Vec;

import java.awt.Color;
import java.io.File;
import java.awt.Point;
import java.util.*;
import javax.imageio.ImageIO;

class Circle {

    double x, y, r, a;
    public PixM m;
    Color c;
    double i;

    public Circle(PixM m, double x, double a,
                  double y, double r) {
        this.x = x;
        this.y = y;
        this.r = r;
        this.a = a;
        this.m = m;
    }

    public void rotate(double angle) {
        a += angle;
    }

    public double get(double r, double g, double b) {
        return Math.sqrt(r * r + g * g + b * b);
    }


    public Point3D get(double a, double r) {
        Point3D n = new Point3D(r * Math.cos(2 * Math.PI * a),
                r * Math.sin(2 * Math.PI * a), 0.0);
        return n;
    }

    public void variate(double x, double y,
                        double r, double rotate) {
        this.x += x;
        this.y += y;
        this.r += r;
        this.a += rotate;
    }

    public double getIntensity(int i, int j) {
        double count = 0.0;
        double
                i0, j0;


        double iin = 0.0;

        double tin = 0.0;
        for (i0 = i - r; i0 < i + r; i0++) {
            for (j0 = i - r; j0 < i + r; j0++) {

                if (Math.sqrt((i0 - i) * (i0 - i)
                        + (j0 - j) * (j0 - j))
                        <= r) {
                    count++;
                    iin = m.getIntensity((int) i0, (int) j0);
                    tin += iin;
                }
            }
        }


        return tin / count;
    }

    public Circle getLevel() {
        Circle c = this;
        // I mean. Parcourir le cercle
        // mesurer I / numPoints
        // for(int i=Math.sqrt()
        //  return c;
        int count = 0;
        double intensity = 0.0;
        c.r = r;
        for (double i = c.x - c.r; i <= c.x + c.r; i++) {
            for (double j = c.y - c.r; j <= c.y + c.r; j++) {
                if (Math.sqrt((i - c.x) * (i - c.x) + (j - c.y) * (j - c.y)) <= c.r * c.r
                        && c.x - c.r >= 0 && c.y - c.r >= 0 && c.x + c.r < c.m.getColumns() && c.y + c.r < c.m.
                        getLines()) {
                    intensity += c.m.getIntensity((int) i, (int) j);
                    count++;

                }
            }
        }

        if (count > 0) {
            c.i = intensity / count;
        } else {
            c.i = 0.0;
            c.r = 0.0;
        }


        return c;

    }

    public double match(Circle b) {
        return getLevel().getIntensity((int) x, (int) y) - b.getLevel().getIntensity((int) b.x, (int) b.y);


    }
               /*
                     public double dist(Circle b) {
           
            double diff = 0.0;
              
            for(int i = (int)(-b.x+ b.r); i




© 2015 - 2025 Weber Informatics LLC | Privacy Policy