3

想自动化并仅捕获地图部分并将其保存到不同的文件中,即删除矩形之外的任何东西。我尝试探索 Photoshop 的魔杖改进边缘工具,但不确定我的方法中是否遗漏了任何东西。看起来裁剪或修剪可能无法实现自动化,因为每个图像的尺寸都不同。

注意:矩形边框并不适用于每个图像,即每边的边框宽度可能会有所不同,并且矩形的尺寸也可能会有所不同。我有 1000 多张地图,自动化将加快任务速度。

在此先感谢您的任何输入、推荐![在此处输入图像描述][1]s 等。

参考地图: http ://www.google.com/imgres?imgurl=http%3A%2F%2Fwww.portal.gsi.gov.in%2Fimages%2FGSIimages%2FSTATUS_Map_AirborneSurveys_11-12.gif&imgrefurl=http%3A%2F%2Fwww .portal.gsi.gov.in%2Fpls%2Fportal%2Furl%2Fpage%2FGSI_STATIC%2FGSI_STAT_SEARCH_AMSE%3FlinkId%3D1032&h=4018&w=2651&tbnid=Bgkcf16ZBBhB9M%3A&zoom=1&docid=azCZJ7k99sm84M&ei=WzFBVN7YArS1sQSr_oGAAg&tbm=isch&ved=0CB4QMygAMAA&iact=rc&uact=3&dur=9105&page=1&start =0&ndsp=26

4

2 回答 2

1

更新的答案

好的,我在这方面做了一些工作,并且可以使用下面的脚本自动提取地图,该脚本或多或少地按照我在下面的建议:

#!/bin/bash 
################################################################################
# File: extractMap
# Usage:
# extractMap survey.gif
# Result is in extracted/survey.gif
################################################################################
image="$1"
mkdir extracted 2> /dev/null

# Step1: Trim off border around edge of image
convert "$image" -shave 50x50 step1.gif

# Step 2: Squeeze image till 1 pixel wide x original height
convert step1.gif -scale 1x! -threshold 65533 step2.gif

# Step 3: Find longest black line
result=$(convert step2.gif txt: | awk -F"[,: ]*" '/black/&&!inblack{inblack++;start=$2}/white/&&inblack{inblack=0;l=$2-start;if(l>longest){longest=l;x=start;y=$2}}END{print x,y}')
read a b <<< $result

# Step 4: Crop top and bottom off
h=$(identify -format "%h" step1.gif)
c=$((h-b))
convert step1.gif -chop 0x$a -gravity south -chop 0x$c out.gif

# Step 5: Squeeze image till 1 pixel tall
convert out.gif -scale x1! -threshold 65533 step3.gif

# Step 6: Find longest black line
result=$(convert step3.gif txt: | awk -F"[,: ]*" '/black/&&!inblack{inblack++;start=$1}/white/&&inblack{inblack=0;l=$1-start;if(l>longest){longest=l;x=start;y=$1}}END{print x,y}')
read a b <<< $result

# Step 7: Crop left and right off
w=$(identify -format "%w" out.gif)
c=$((w-b))
convert out.gif -chop ${a}x0 -gravity east -chop ${c}x0 "extracted/$image"

您可以将上面的脚本保存在一个名为 的文件中extractMap,然后运行以下(仅一次)以使其可执行

chmod +x extractMap

现在您可以像这样将调查的名称传递给它,它会将地图提取到一个名为的子目录中,extracted后跟原始文件名:

./extractMap survey.gif

主要步骤是:

  1. 去除原始图像周围的黑色边框
  2. 然后将图像压缩到 til1 1 像素宽和原始高度
  3. 在压缩后的图像中找到最长的黑线(即地图的垂直边缘)
  4. 根据那条线裁剪顶部和底部
  5. 将图像压缩到 1 像素高
  6. 找到最长的黑线,即地图区域的水平边缘
  7. 裁剪地图边框的左右并保存在输出目录中

如果您有一个完整的目录中的图像,请先备份它们,然后您可以像这样处理数千个文件的整个目录:

for f in *.gif; do ./extractMap "$f"; done

原始答案

我在周末无法访问我的电脑,所以我只能笼统地建议如何去做......将在周日晚上回来看看是否有人提出了这个想法。

我会使用 ImageMagick,它通过命令行或 Perl、PHP、.NET 和其他绑定可用于 Windows、Linux 和 OSX。

然后使用此命令将图像压缩成一个高、1 像素宽的图像

convert inputimage.jpg -resize 1x\! output.jpg

现在看图像,你会看到一条短实线对应于左上角的图像标题栏,然后是另一条短线对应于经度,然后是一条长实线对应于地图的两侧。这很容易识别,并为您提供地图的顶部和底部。

现在用这个将图像压缩到 1 像素高

convert inputimage.jpg -resize x1\! output.jpg

然后再做一次以找到地图的宽度。

然后提取地图

convert inputimage.jpg -crop XxY+M+N output.jpg

其中 X=地图宽度,Y=地图高度,M=x 到地图左上角的偏移量,N=y 到地图左上角的偏移量。

您可以将输出图像名称更改为txt:-,它将像素颜色列为文本,以便您轻松解析它们。

再想一想,最好在找到最长的垂直线之后裁剪图像的顶部和底部,然后再将图像压缩到 1 个像素高 - 这意味着顶部的标题和底部的键将不干扰确定地图的宽度。

于 2014-10-17T16:59:26.817 回答
0

看起来你只能部分自动化这个过程。这是我要做的:

1) 将所有图像/地图保存到一个文件夹中。

2) 在 Photoshop 中打开第一张图像/地图。

3) 使用“矩形选框工具”绘制您想要保留的地图部分。

4) 现在转到“动作”面板,然后单击面板底部的“创建新动作”图标。

5) 给动作命名并设置一个“功能键” - 像 F5 这样的东西会很好地工作。然后点击“记录”

6) 从屏幕顶部选择“图像”菜单,然后选择“裁剪”。

7)选择“文件”,“保存为网络”,选择您的格式(JPG,GIF,PNG)和质量设置,点击“保存”并将其保存到一个单独的文件夹中(与您的源图像不同)

8)关闭您的原始地图(您可以根据需要选择是或否来保存您的更改)

9) 在“动作”面板中,点击“停止”停止录制。

10) 现在您可以打开一堆地图(可能是 20-30 个),选择矩形选框并点击操作快捷键(本例中为 F5)。

这种方法需要一些时间,但主要是自动化该过程并且会很快进行。

于 2014-10-17T17:34:39.100 回答