- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
所以我正在尝试生成柏林噪声并将其保存到图像文件中。我已经正确保存了图像,但噪声看起来并不像柏林噪声。
这是我的代码:
package com.egs.survivalsim.util;
import java.awt.Color;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;
import com.egs.survivalsim.MainComponent;
public class Noise {
MainComponent main;
public double noise(int x,int y){
x = x + y * 57;
x = ((x << 13) ^ x);
double t = (x * (x * x * 15731 + 789221) + 1376312589) & 0x7fffffff;
return 1 - t * 0.000000000931322574615478515625;
}
public double sNoise(int x, int y){
double corners = (noise(x - 1, y - 1) + noise(x + 1, y - 1) + noise(x - 1, y + 1) + noise(x + 1, y + 1)) * 0.0625;
double sides = (noise(x - 1, y) + noise(x + 1, y) + noise(x, y - 1) + noise(x, y + 1)) * 0.125;
double center = noise(x, y) * 0.25;
return corners + sides + center;
}
public double lInterpoleLin(double a, double b, double x){
return a * (1 - x) + b * x;
}
public double lInterpoleCos(double a, double b, double x){
double ft = x * 3.1415927;
double f = (1 - Math.cos(ft)) * 0.001;
return a * (1 - f) + b * f;
}
public double iNoise(double x, double y){
int iX = (int) x;
int iY = (int) y;
double dX = x - iX;
double dY = y - iY;
double p1 = sNoise(iX, iY);
double p2 = sNoise(iX + 1, iY);
double p3 = sNoise(iX, iY + 1);
double p4 = sNoise(iX + 1, iY + 1);
double i1 = lInterpoleCos(p1 ,p2 ,dX);
double i2 = lInterpoleCos(p3, p4, dX);
return lInterpoleCos(i1, i2, dY);
}
public double pNoise(double x, double y, double persistence, int octave){
double result;
double amplitude = 1;
int frequence = 1;
result = 0;
for(int n = 0; n < octave; n++){
frequence <<= 1;
amplitude *= persistence;
result += iNoise(x * frequence, y * frequence) * amplitude;
}
return result;
}
public void startNoise(MainComponent main){
System.out.println("Generating noise map");
this.main = main;
System.out.println("Width: " + main.worldWidth);
System.out.println("Height: " + main.worldHeight);
BufferedImage image = new BufferedImage(main.worldWidth, main.worldHeight, BufferedImage.TYPE_INT_RGB);
for(int y = 0; y < main.worldHeight; y++){
for(int x = 0; x < main.worldWidth; x++){
double c = pNoise((double) x - main.worldWidth, (double) y - main.worldHeight, 0.2, 2);
c *= 128.0;
c += 127.0;
if(c > 255.0){
c = 255.0;
}
if(c < 0.0){
c = 0.0;
}
int r = (int) c;
int g = (int) c;
int b = (int) c;
if(c>128)
r>>=1;
if(c>128)
b>>=1;
int color = new Color(r, g, b).getRGB();
image.setRGB(x, y, color);
main.noiseArray[x][y] = (int) c;
}
}
File fileImage = new File("noise.png");
try {
ImageIO.write(image, "png", fileImage);
} catch (IOException e) {
e.printStackTrace();
}
System.out.println("Noise map generated");
}
}
最佳答案
不,确实这看起来有点奇怪。首先,噪音的产生似乎存在问题。其次,我真的不知道你为什么要创建彩色图像。最快的解决方案是查看最新发布的 Ken Perlin看看他的 reference implementation为了它。
通过简单的复制和粘贴以及几行额外的 java 代码,您可以获得漂亮的图像。
请注意,我真的只是把它砍掉了,这意味着我手动缩放了采样范围以使其看起来不错,并且由于我不知道 Perlin 噪声的值在哪个范围内,所以我只是重新缩放了数组以适应范围 [0, 255]。
在下面的代码中,只有 main
是重要的。其余部分是从 Perlin 复制的。
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
public class Noise {
static final int p[] = new int[512], permutation[] = {151, 160, 137, 91, 90, 15,
131, 13, 201, 95, 96, 53, 194, 233, 7, 225, 140, 36, 103, 30, 69, 142, 8, 99, 37, 240, 21, 10, 23,
190, 6, 148, 247, 120, 234, 75, 0, 26, 197, 62, 94, 252, 219, 203, 117, 35, 11, 32, 57, 177, 33,
88, 237, 149, 56, 87, 174, 20, 125, 136, 171, 168, 68, 175, 74, 165, 71, 134, 139, 48, 27, 166,
77, 146, 158, 231, 83, 111, 229, 122, 60, 211, 133, 230, 220, 105, 92, 41, 55, 46, 245, 40, 244,
102, 143, 54, 65, 25, 63, 161, 1, 216, 80, 73, 209, 76, 132, 187, 208, 89, 18, 169, 200, 196,
135, 130, 116, 188, 159, 86, 164, 100, 109, 198, 173, 186, 3, 64, 52, 217, 226, 250, 124, 123,
5, 202, 38, 147, 118, 126, 255, 82, 85, 212, 207, 206, 59, 227, 47, 16, 58, 17, 182, 189, 28, 42,
223, 183, 170, 213, 119, 248, 152, 2, 44, 154, 163, 70, 221, 153, 101, 155, 167, 43, 172, 9,
129, 22, 39, 253, 19, 98, 108, 110, 79, 113, 224, 232, 178, 185, 112, 104, 218, 246, 97, 228,
251, 34, 242, 193, 238, 210, 144, 12, 191, 179, 162, 241, 81, 51, 145, 235, 249, 14, 239, 107,
49, 192, 214, 31, 181, 199, 106, 157, 184, 84, 204, 176, 115, 121, 50, 45, 127, 4, 150, 254,
138, 236, 205, 93, 222, 114, 67, 29, 24, 72, 243, 141, 128, 195, 78, 66, 215, 61, 156, 180
};
static {
for (int i = 0; i < 256; i++) p[256 + i] = p[i] = permutation[i];
}
static public double noise(double x, double y, double z) {
int X = (int) Math.floor(x) & 255, // FIND UNIT CUBE THAT
Y = (int) Math.floor(y) & 255, // CONTAINS POINT.
Z = (int) Math.floor(z) & 255;
x -= Math.floor(x); // FIND RELATIVE X,Y,Z
y -= Math.floor(y); // OF POINT IN CUBE.
z -= Math.floor(z);
double u = fade(x), // COMPUTE FADE CURVES
v = fade(y), // FOR EACH OF X,Y,Z.
w = fade(z);
int A = p[X] + Y, AA = p[A] + Z, AB = p[A + 1] + Z, // HASH COORDINATES OF
B = p[X + 1] + Y, BA = p[B] + Z, BB = p[B + 1] + Z; // THE 8 CUBE CORNERS,
return lerp(w, lerp(v, lerp(u, grad(p[AA], x, y, z), // AND ADD
grad(p[BA], x - 1, y, z)), // BLENDED
lerp(u, grad(p[AB], x, y - 1, z), // RESULTS
grad(p[BB], x - 1, y - 1, z))),// FROM 8
lerp(v, lerp(u, grad(p[AA + 1], x, y, z - 1), // CORNERS
grad(p[BA + 1], x - 1, y, z - 1)), // OF CUBE
lerp(u, grad(p[AB + 1], x, y - 1, z - 1),
grad(p[BB + 1], x - 1, y - 1, z - 1))));
}
static double fade(double t) {
return t * t * t * (t * (t * 6 - 15) + 10);
}
static double lerp(double t, double a, double b) {
return a + t * (b - a);
}
static double grad(int hash, double x, double y, double z) {
int h = hash & 15; // CONVERT LO 4 BITS OF HASH CODE
double u = h < 8 ? x : y, // INTO 12 GRADIENT DIRECTIONS.
v = h < 4 ? y : h == 12 || h == 14 ? x : z;
return ((h & 1) == 0 ? u : -u) + ((h & 2) == 0 ? v : -v);
}
public static void main(String[] args) {
final int WIDTH = 2 * 256, HEIGHT = 256;
double[] data = new double[WIDTH * HEIGHT];
int count = 0;
for (int y = 0; y < HEIGHT; y++) {
for (int x = 0; x < WIDTH; x++) {
data[count++] = PerlinNoise.noise(20.0 * x / WIDTH, 10.0 * y / HEIGHT, 0);
}
}
double minValue = data[0], maxValue = data[0];
for (int i = 0; i < data.length; i++) {
minValue = Math.min(data[i], minValue);
maxValue = Math.max(data[i], maxValue);
}
int[] pixelData = new int[WIDTH * HEIGHT];
for (int i = 0; i < data.length; i++) {
pixelData[i] = (int) (255 * (data[i] - minValue) / (maxValue - minValue));
}
BufferedImage img = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_BYTE_GRAY);
img.getRaster().setPixels(0, 0, WIDTH, HEIGHT, pixelData);
File output = new File("image.jpg");
try {
ImageIO.write(img, "jpg", output);
} catch (IOException e) {
e.printStackTrace();
}
}
}
关于java - Java 中的 Perlin 噪声问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19184419/
我正在研究我的论文,以构建乐谱(乐谱)识别系统。这是我的输入文件: 这是一些预处理和去除五线谱后的结果: 我在这里遇到的问题是,在五线谱删除步骤之后出现了一些超小的、不需要的“点”。这些点/噪声与实际
这可能是一个愚蠢的问题(当然),但对于我已阅读/发现的所有内容,没有一个与我想做的相匹配......这是 GIT 的基本情况。 为了使我的情况更简单,我有两个分支: - master(主要分支) -
我的项目: 我正在开发一辆带有 3 轴加速度计和陀螺仪的槽车,试图估计汽车姿态(x、y、z、偏航、俯仰),但我的振动噪音有一个大问题(而汽车在例如,加速度计的噪声值在 ±4[g](其中 g = 9.8
我正在尝试实现 2D Perlin 噪声来创建类似 Minecraft 的地形(Minecraft 实际上并不使用 2D Perlin 噪声)而没有悬垂或洞穴之类的东西。 我这样做的方式是创建一个 [
我有一个代表图像的二维数组。我必须向图像添加 RMS 2 单位的背景高斯噪声。我不熟悉噪声的 RMS 测量以及如何添加它。您能否告诉我如何执行此操作? 最佳答案 按照我的理解,您想要在每个像素处添加遵
更新:正式问题列表: 2D 噪声实现的浮点值(输入参数和输出)代表什么? - 部分回答,输入是坐标。输出怎么样?另外,我可以使用我的整数作为坐标的 float 吗? 1.0、122.0 等? 在 2D
我正在尝试使用 Perlin 噪声生成地形。我了解如何使用笛卡尔坐标生成它,但无法完全理解它在球体上的工作方式。我知道您可以将 2D 表面投影到球体上,但失真不会扰乱噪声分布吗?要在球体表面生成均匀噪
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在尝试将 fBm 实现到行星的球体上。为了创建我的球体,我将其从立方体转换为此类。不幸的是,生成的 fBm 显示为镜像补丁。此外,它只在 2 个面上执行(包装其他面的值)。当呈现为 sphere
我想知道为什么在 Simplex 推出后,Perlin 噪声至今仍然如此流行。单纯形噪声是由 Ken Perlin 自己制作的,它应该取代他的旧算法,该算法对于更高的维度来说速度较慢,但质量更好(
我终于设法为 Love 2D 编写了 Perlin 改进噪音的工作 Lua 版本。但是,当我运行它时,我得到了这个: 我想这很好。但我想要看起来更像这样的东西: 我怎样才能做到这一点? 最佳答案 第一
我终于设法为 Love 2D 编写了 Perlin 改进噪音的工作 Lua 版本。但是,当我运行它时,我得到了这个: 我想这很好。但我想要看起来更像这样的东西: 我怎样才能做到这一点? 最佳答案 第一
我正在尝试处理我从采样源数据行(Java Sound API)获得的字节数组。如果我将字节数组与小数相乘,播放流时会产生噪音。 在播放声音之前,我将立体声 wav 文件分成左右声道。这很好用。但是,如
对于我正在进行的元胞自动机项目,我需要使用不同的算法和技术随机生成二维 boolean 数组。目前,我在应用程序中只有一种随机化类型——循环遍历数组中的每个单元格并生成一个随机 double 变量,然
我叫 Chris,正在开发我的第一个 Java 游戏。到目前为止,我已经创建了一个基于图 block 的 2D 游戏,但是我的关卡是以这样一种方式完成的,如果我创建一个图像并且它全是绿色,那么绿色就代
block 之间的平滑 所以我一直在开发一个统一的游戏,想将我的世界从 150x150 的 map 扩展到一个看似无限的程序世界。我的计划是以Perlin Noise为基础,使用0-1的不同值来判断地
(此程序的依赖项:vector --any 和 JuicyPixels >= 2 。代码可用作 Gist。) {-# LANGUAGE Haskell2010 #-} {-# LANGUAGE Ban
我最近用 C# 编写了 Diamond-Square 过程生成算法的实现。但是,生成的噪声在所处理的“正方形”之间具有非常明显的边界。伪代码看起来像这样 gen() { This takes
我已经尝试了所有方法并阅读了我在互联网上看到的关于 Perlin Noise 或 Simplex Noise 的每一个链接,甚至剖析了一些我认为工作正常的 Javascript 示例。 但我仍然得到看
我在任何方面都不精通视频压缩,但目前正在从事一个使用 H.264 压缩残差图像的项目 我的问题更多是关于视频编码器的一般性问题。据我了解(正如维基百科所解释的那样), block 运动补偿编码器将当前
我是一名优秀的程序员,十分优秀!