我有一段代码可以获取flickr的图像网址现在我希望这些网址中的图像保存在一个数组中,以便我以后可以使用它们。但我不断收到以下错误:
文件https://www.flickr.com/photos/7851888@N08/22115289859包含错误的图像数据,或者可能不是图像
看我的代码: 在代码中将是一个注释,以显示我认为生成错误的行。
PImage[] images;
int imageIndex;
XML xml;
String tag_mode = "all";
String words[];
PImage[] displayImages;
int amount = 500;
void setup() {
size(50, 50);
String lines[] = loadStrings("text.txt");
words = split(lines[0], " ");
displayImages = new PImage[amount];
for (int k = 0; k<words.length; k++) {
String query = "https://api.flickr.com/services/rest/?method=flickr.photos.search&api_key=MYKEY&tags="+ words[k] + "&sort=relevance&extras=url_o&tag_mode="+ tag_mode +"format=rest";
xml = loadXML(query);
XML[] children = xml.getChildren("photos");
if (children.length > 0) {
XML[] childPhoto = children[0].getChildren("photo");
// println(childPhoto);
if (childPhoto.length > 0) {
for (int i = 0; i < 1; i++) {
String id = childPhoto[i].getString("id");
String title = childPhoto[i].getString("title");
String user = childPhoto[i].getString("owner");
String url = "https://www.flickr.com/photos/"+user+"/"+id;
println(url);
println("=====================");
displayImages[i] = loadImage(url, "jpg"); // here is probably the error
println(displayImages.length);
}
}
}
}
textAlign(CENTER, CENTER);
smooth();
}
void draw() {
}
答案 0 :(得分:1)
您提供的网址不是图片的网址。它是flickr网页的URL。您必须提取实际图像URL,而不仅仅是页面URL。
例如,这是您要访问的网址:https://www.flickr.com/photos/7851888@N08/22115289859
这是页面,而不是图片。这就是您收到错误的原因:处理方法并不知道如何从页面创建图像。
该页面恰好包含一张图片,但Processing并不够聪明,无法解决这个问题。对于它的价值,该图片的网址是:https://c2.staticflickr.com/6/5826/22115289859_91944c93cb_b.jpg
您必须在页面上找到图片网址。它可能在xml结构中的某个地方。