使用 Unsplash API 生成随机图片
2021-06-28
Unsplash提供免费版权图片,支持通过URL随机获取图片、指定用户、尺寸和关键词搜索,并提供API和代码示例。
Unsplash
如果你想使用免费版权的图片时,无论你是否用于商业用途,Unsplash 是不错的选择。 (https://www.imyangyong.com/) 。
虽然他们为开发人员提供了很棒的 API,但他们也提供了通过 URL 访问随机图片的选项。
1. 默认随机
请看这个例子,从他们巨大的存储中生成随机的图片。
https://source.unsplash.com/random
指定用户
我们还可以从特定用户账号中生成随机图像。URL 格式是这样的:
https://source.unsplash.com/user/{USERNAME}
你可以尝试单击下面的链接,从我的账号中随机生成图片:
https://source.unsplash.com/user/angusyang9/likes
3. 指定尺寸
还有一个选项可以设置要生成的图像的大小。像这样:
https://source.unsplash.com/random/{WIDTH}x{HEIGHT}
让我们生成下 300 x 300 大小的图片:
https://source.unsplash.com/random/300×300
4. 依据关键词搜索
这个真的很棒。你可以从搜索词生成图像。让我们搜索食品相关的内容(非常有创意):
https://source.unsplash.com/random/300x300?food
当然,你可以与尺寸配合使用:
https://source.unsplash.com/random/900×700/?fruit
代码示例
以下是 react 中的代码片段:
class RandomImg extends React.Component {
constructor() {
super();
this.state = {
bgImageUrl: require('./default.jpeg')
}
}
componentDidMount() {
this.generateImage();
}
generateImage(){
fetch(`https://source.unsplash.com/random/?people`).then((response) => {
preloadImage(response.url);
})
}
preloadImage(url) {
let img = new Image();
img.src = url;
img.onload = () => {
this.setState({
bgImageUrl: url
});
}
}
render() {
return <img src={bgImageUrl} />
}
}