gpt4 book ai didi

java - 在java中将图像转换为圆柱形

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:24:49 24 4
gpt4 key购买 nike

我没有在 openCV 中找到任何在 java 中将平面图像转换为圆柱形图像的示例,我希望它以 2d 而不是 3d 渲染图像,也没有' 找到有关它的任何示例代码或书籍。下面是我想围绕杯子扭曲的图片图像。

一本好书和示例代码将不胜感激。

enter image description here

enter image description here

enter image description here

到目前为止我已经完成了。建议我的@Amitay 使用此示例使图像凹陷 Wrap image around cylinder 但坚持转换。

import java.io.File;
import org.bytedeco.javacpp.indexer.UByteBufferIndexer;
import org.bytedeco.javacpp.opencv_core.Mat;
import org.bytedeco.javacpp.opencv_core.*;
import static org.bytedeco.javacpp.opencv_highgui.imshow;
import static org.bytedeco.javacpp.opencv_highgui.waitKey;
import static org.bytedeco.javacpp.opencv_imgcodecs.CV_LOAD_IMAGE_COLOR;
import static org.bytedeco.javacpp.opencv_imgcodecs.imread;

/**
*
* @author BTACTC
*/
public class CupWrapping {

Mat image;
Mat dstImage;

int width;
int height;

public CupWrapping(File imageFile) {

image = imread(imageFile.getAbsolutePath(), CV_LOAD_IMAGE_COLOR);

width = image.size().width();
height = image.size().height();

dstImage = new Mat(width, height, image.type());

UByteBufferIndexer sI = image.createIndexer();
UByteBufferIndexer sD = dstImage.createIndexer();

for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
Point2f current_pos = new Point2f(x, y);
current_pos = convert_pt(current_pos, width, height);
Point top_left = new Point((int) current_pos.x(), (int) current_pos.y()); //top left because of integer rounding

//make sure the point is actually inside the original image
if (top_left.x() < 0
|| top_left.x() > width - 2
|| top_left.y() < 0
|| top_left.y() > height - 2) {
continue;
}

//bilinear interpolation
float dx = current_pos.x() - top_left.x();
float dy = current_pos.y() - top_left.y();

float weight_tl = (float) ((1.0 - dx) * (1.0 - dy));
float weight_tr = (float) ((dx) * (1.0 - dy));
float weight_bl = (float) ((1.0 - dx) * (dy));
float weight_br = (dx) * (dy);

byte value = (byte) (weight_tl * sI.get(top_left.y(), top_left.x())
+ weight_tr * sI.get(top_left.y(), top_left.x() + 1)
+ weight_bl * sI.get(top_left.y() + 1, top_left.x())
+ weight_br * sI.get(top_left.y() + 1, top_left.x() + 1));
sD.put(y, x,value);
}
}

imshow("", dstImage);

waitKey(0);

}

public Point2f convert_pt(Point2f point, int w, int h) {
//center the point at 0,0
Point2f pc = new Point2f(point.x() - w / 2, point.y() - h / 2);

//these are your free parameters
float f = w;
float r = w;

float omega = w / 2;
float z0 = (float) (f - Math.sqrt(r * r - omega * omega));

float zc = (float) ((2 * z0 - Math.sqrt(4 * z0 * z0 - 4 * (pc.x() * pc.x() / (f * f) + 1) * (z0 * z0 - r * r))) / (2 * (pc.x() * pc.x() / (f * f) + 1)));
Point2f final_point = new Point2f(pc.x() * zc / f, pc.y() * zc / f);
final_point.x() = final_point.x() + w / 2;
final_point.y() += h / 2;
return final_point;

}

public static void main(String[] args) {

File imageFile = new File("image/C13.jpg");
CupWrapping wrap = new CupWrapping(imageFile);
}

}

最佳答案

查看 Warp Image to Appear in Cylindrical Projection 中的这个答案

你只需要改变两件事:

  1. 因为您需要凸投影而不是凹投影,所以您需要更改函数 convert_pt 中的代码行。

来自:

float zc = (2*z0+sqrt(4*z0*z0-4*(pc.x*pc.x/(f*f)+1)*(z0*z0-r*r)))/(2* (pc.x*pc.x/(f*f)+1));

float zc = (2*z0-sqrt(4*z0*z0-4*(pc.x*pc.x/(f*f)+1)*(z0*z0-r*r)))/(2* (pc.x*pc.x/(f*f)+1));
  1. 将所有其余代码从 C++ 转换为 Java。

祝你好运

关于java - 在java中将图像转换为圆柱形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39944635/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com