diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..e69de29 diff --git a/Concatenate Images.workflow/Contents/Info.plist b/Concatenate Images.workflow/Contents/Info.plist new file mode 100644 index 0000000..454c4be --- /dev/null +++ b/Concatenate Images.workflow/Contents/Info.plist @@ -0,0 +1,27 @@ + + + + + NSServices + + + NSMenuItem + + default + Concatenate Images + + NSMessage + runWorkflowAsService + NSRequiredContext + + NSApplicationIdentifier + com.apple.finder + + NSSendFileTypes + + public.image + + + + + diff --git a/Concatenate Images.workflow/Contents/QuickLook/Preview.png b/Concatenate Images.workflow/Contents/QuickLook/Preview.png new file mode 100644 index 0000000..986f7ad Binary files /dev/null and b/Concatenate Images.workflow/Contents/QuickLook/Preview.png differ diff --git a/Concatenate Images.workflow/Contents/document.wflow b/Concatenate Images.workflow/Contents/document.wflow new file mode 100644 index 0000000..08f48d5 --- /dev/null +++ b/Concatenate Images.workflow/Contents/document.wflow @@ -0,0 +1,227 @@ + + + + + AMApplicationBuild + 428 + AMApplicationVersion + 2.7 + AMDocumentVersion + 2 + actions + + + action + + AMAccepts + + Container + List + Optional + + Types + + com.apple.cocoa.string + + + AMActionVersion + 2.0.3 + AMApplication + + Automator + + AMParameterProperties + + COMMAND_STRING + + CheckedForUserDefaultShell + + inputMethod + + shell + + source + + + AMProvides + + Container + List + Types + + com.apple.cocoa.string + + + ActionBundlePath + /System/Library/Automator/Run Shell Script.action + ActionName + Run Shell Script + ActionParameters + + COMMAND_STRING + #!/bin/bash +set -e + +OLDIFS=$IFS +IFS="$(printf '\n\t')" + +NEWLINE=$'\n' + +FILES="" +for file in $@; do + if [ -e "$file" ] ; then + FILES="$FILES$file$NEWLINE" + fi +done + +# FILES=$(echo "$FILES" | sed -e 's/ /\ +# /g' | perl -e '$f=sub{eval(`/usr/local/bin/identify -format %w*%h ${\quotemeta(shift)} 2>/dev/null`)};print sort{$f->($b)<=>$f->($a)}<>') +# +FILES=$(echo "$FILES" | perl -e '$f=sub{eval(`/usr/local/bin/identify -format %w*%h ${\quotemeta(shift)} 2>/dev/null`)};print sort{$f->($b)<=>$f->($a)}<>') + +/usr/local/bin/montage -mode Concatenate -gravity "SouthWest" -tile x1 -geometry '+0+0' $FILES /tmp/concatenate-images-output.png + +osascript -e 'set the clipboard to (read (POSIX file "/tmp/concatenate-images-output.png") as JPEG picture)' + +/usr/local/bin/terminal-notifier -message "Combined image copied to clipboard." -title "Concatenate Images" -contentImage "file:///tmp/concatenate-images-output.png" -open "file:///tmp/concatenate-images-output.png" -sender "com.apple.Preview" -group "Concatenate-Images" + +IFS=$OLDIFS + CheckedForUserDefaultShell + + inputMethod + 1 + shell + /bin/bash + source + + + BundleIdentifier + com.apple.RunShellScript + CFBundleVersion + 2.0.3 + CanShowSelectedItemsWhenRun + + CanShowWhenRun + + Category + + AMCategoryUtilities + + Class Name + RunShellScriptAction + InputUUID + 1397A8A3-425A-43B0-9FA5-1B7AD416CBBB + Keywords + + Shell + Script + Command + Run + Unix + + OutputUUID + 62A619F4-4F44-42A8-BA6D-336D00D64160 + UUID + 2C20EA4A-8E05-4ACF-8631-4CC727425C4B + UnlocalizedApplications + + Automator + + arguments + + 0 + + default value + 0 + name + inputMethod + required + 0 + type + 0 + uuid + 0 + + 1 + + default value + + name + source + required + 0 + type + 0 + uuid + 1 + + 2 + + default value + + name + CheckedForUserDefaultShell + required + 0 + type + 0 + uuid + 2 + + 3 + + default value + + name + COMMAND_STRING + required + 0 + type + 0 + uuid + 3 + + 4 + + default value + /bin/sh + name + shell + required + 0 + type + 0 + uuid + 4 + + + isViewVisible + + location + 309.000000:433.000000 + nibPath + /System/Library/Automator/Run Shell Script.action/Contents/Resources/English.lproj/main.nib + + isViewVisible + + + + connectors + + workflowMetaData + + serviceApplicationBundleID + com.apple.finder + serviceApplicationPath + /System/Library/CoreServices/Finder.app + serviceInputTypeIdentifier + com.apple.Automator.fileSystemObject.image + serviceOutputTypeIdentifier + com.apple.Automator.nothing + serviceProcessesInput + 0 + workflowTypeIdentifier + com.apple.Automator.servicesMenu + + + diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..bcdedae --- /dev/null +++ b/LICENSE @@ -0,0 +1,7 @@ +Copyright 2017 Jason Sadler + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..f3e3c33 --- /dev/null +++ b/README.md @@ -0,0 +1,45 @@ +Concatenate Images Automator Workflow +=== + +An Automator workflow that combines several images into a single file with each image in a row, from largest to smallest. Its original purpose was to put screenshots from iOS simulators of different sizes into one image. This has been super useful to show designers and code reviewers what a UI will look like on all supported devices at once. + +Prerequisites +--- +This workflow uses `imagemagick` to create the image and `terminal-notifier` to communicate that work is complete. + +```bash +brew install imagemagick +brew install terminal-notifier +``` + +Installation +--- +Copy `Concatenate Images.workflow` into `~/Library/Services`. That's it! + +Usage +--- +Select the images you want to combine in Finder, right click, and select `Concatenate Images` from the `Services` sub-menu. This will take a few seconds, so be patient. A notification will show when the task is complete. + +The final image will show all selected images in a horizontal row, in order from largest to smallest, regardless of which order in which the images were selected. + +After the workflow completes: +- The final image should be in your clipboard +- The final image will be saved at `/tmp/concatenate-images-output.png` +- Clicking on the notification will open the image from its location in `/tmp` + +Example +--- +I've taken screenshots of the home screens from simulators for iPhone 4s, iPhone 5, iPhone 6, and iPhone 6s. + +Running the workflow: +![Screenshot of selecting images and running Concatenate Images workflow from the Services menu](example-images/usage-1.png) + +The notification saying work is complete: +![Screenshot of the notification](example-images/usage-2.png) + +The results: +![The results of running the workflow](example-images/concatenate-images-output.png) + +License +--- +[MIT License](LICENSE) diff --git a/example-images/concatenate-images-output.png b/example-images/concatenate-images-output.png new file mode 100644 index 0000000..0e7f13e Binary files /dev/null and b/example-images/concatenate-images-output.png differ diff --git a/example-images/usage-1.png b/example-images/usage-1.png new file mode 100644 index 0000000..9c5a0a6 Binary files /dev/null and b/example-images/usage-1.png differ diff --git a/example-images/usage-2.png b/example-images/usage-2.png new file mode 100644 index 0000000..fdb1845 Binary files /dev/null and b/example-images/usage-2.png differ