R magick:方形裁剪和圆形蒙版

rmf*_*rmf 3 r rmagick imagemagick image-processing

目的是

  1. 将任何输入图像转换为正方形长宽比并且
  2. 添加圆形蒙版并用白色或透明填充外部。

我有 1 个工作要做,但不确定这是最好的方法。这是一个工作示例。

library(magick)
path <- "https://cdn.pixabay.com/photo/2016/08/17/21/12/people-1601516_960_720.jpg"
img <- magick::image_read(path)
img
Run Code Online (Sandbox Code Playgroud)

原始图像

在此输入图像描述

ii <- magick::image_info(img)
ii_min <- min(ii$width,ii$height)
img1 <- magick::image_crop(img, geometry=paste0(ii_min,"x",ii_min,"+0+0"),repage=TRUE)
img1
Run Code Online (Sandbox Code Playgroud)

裁剪方形纵横比

在此输入图像描述

我不确定如何让最后一部分(2)在 R 中工作。尽管我已经设法在 unix 中使用 image-magick 让它工作。

convert -size 500x500 xc:white -fill cropped.jpeg -draw "circle 250,250 250,1" circ.jpg
Run Code Online (Sandbox Code Playgroud)

圆形框架

在此输入图像描述

我正在寻找R中2的解决方案。

rmf*_*rmf 5

library(magick)
path <- "https://cdn.pixabay.com/photo/2016/08/17/21/12/people-1601516_960_720.jpg"
im <- magick::image_read(path)

# get height, width and crop longer side to match shorter side
ii <- magick::image_info(im)
ii_min <- min(ii$width, ii$height)
im1 <- magick::image_crop(im, geometry=paste0(ii_min, "x", ii_min, "+0+0"), repage=TRUE)

# create a new image with white background and black circle
fig <- magick::image_draw(image_blank(ii_min, ii_min))
symbols(ii_min/2, ii_min/2, circles=(ii_min/2)-3, bg='black', inches=FALSE, add=TRUE)
dev.off()

# create an image composite using both images
im2 <- magick::image_composite(im1, fig, operator='copyopacity')

# set background as white
magick::image_background(im2, 'white')
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

R version 4.0.0
magick_2.5.2
Run Code Online (Sandbox Code Playgroud)