Webカメラで撮影した写真をセピア調に演出するアプリを作る

2013年9月3日(火)
薬師寺 国安

このサンプルにはWebカメラ搭載のPCが必要です。実行すると選択ボックスにWebカメラのデバイスが表示されています。フロントとリアカメラを装備しているタブレットPCでは、2つのデバイスが表示されます。

筆者のデスクトップPCはフロントのWebカメラだけを装備していますので、筆者の顔が表示されています(図1)。

マウスの右クリックで「Attach Camera」、「Sepia調に変換」、「Save Local」、「Folder」アイコンが表示されます(図2)。

「Attach Camera」アイコンをタップすると、シャッター音がして写真が撮られ、「ピクチャライブラリのSepiaSourceImageフォルダに保存しました。」のメッセージが表示されます。「削除」ボタンの付いた写真が下方に追加されます(図3)。

「Sepia調に変換」ボタンをタップすると、写した写真がSepia調に代わります(図4)。

「Save Local」アイコンをタップすると「ピクチャフォルダー内に保存しました。」のメッセージが表示されます(図5)。

「Folder」アイコンをタップすると、「削除」ボタンの付いた、Sepia調に変換された写真の一覧ができます。「削除」ボタンをタップするとSepia調の画像が削除されます(図6)。

Sepia調の画像と、Sepia調に変換する前の写真は別々に保存されていますので、Sepia調の写真を削除しても、元の写真は削除されません。元の写真の削除は図3の「削除」ボタンで削除します。

※このアプリを実行すると、たまにWebカメラに画像が映っていない状況が発生します。その場合は、マウスカーソルを画面の左上隅にもっていき、現在の画面とは異なる別な画面を一度表示してください。その後、再度マウスカーソルを画面の左上隅にもっていくと、現在実行中のプロジェクトの画面が表示されますので、それをタップしてください。Webカメラに画像が表示されます。この手順は今回の動画の中でも説明していますので、見ておいてください。このWebカメラが表示されない原因は、現時点では解決しております。また機会があればサンプルで解説したいと思います。

図1:PCに装備されているWebカメラのデバイスが選択ボックスに表示され、Webカメラからの画像が表示されている(クリックで拡大)
図2:マウスの右クリックでバーが表示され、各アイコンが表示される(クリックで拡大)
図3:「Attach Camera」アイコンをタップするとシャッター音がして写真が撮られ、下方に「削除」ボタン付きで追加表示される(クリックで拡大)
図4:「Sepia調に変換」アイコンをタップして写した画像がSepia調に変換された(クリックで拡大)
図5:「Save Local」アイコンをタップして、Sepia調に変換された画像が、ピクチャフォルダに保存された旨のメッセージが出る(クリックで拡大)
図6:「Folder」アイコンクリックで、「削除」ボタンの付いた、Sepia調に変換された画像の一覧ができる(クリックで拡大)

実際に動かした動画は下記のようになります。スマホで撮影した動画のため、見難い点はご了承願います。

サンプル一式は、会員限定特典としてダウンロードできます。記事末尾をご確認ください。

TOPページに「戻る(←)」ボタンを表示させるのは、Windows ストア・アプリの作法としては好ましくありません。最初はこのボタンは非表示にしておき、別ページに遷移した場合にのみ表示させるのが好ましいです。

プロジェクトの作成

VS 2012のメニューから[ファイル(F)/新規作成(N)/プロジェクト(P)]と選択します。
次に、「テンプレート」から「Windows ストア」を選択し、右に表示される項目名から「新しいアプリケーション(XAML)」を選択します。
「名前(N)」に任意のプロジェクト名を指定します。ここでは「SepiaImage」という名前を付けています。
ソリューションエクスプローラー内のSepiaImageプロジェクトの配下に、WAVというフォルダを作成して、シャッター音となるwavファイルを追加しておきます。

ダウンロードされたサンプルファイルには、wavファイルは追加済みです。

NugetでのWriteableBitmapEffectorの追加

ソリューションエクスプローラーの「参照設定」を選択して、マウスの右クリックで表示される、「NuGetパッケージの管理」をクリックします。
表示される画面で「オンライン」を選択し、検索ボックスにwriteablebitmapと入力します。するとWriteableBitmapEffectorが表示されますので、「インストール」をクリックしてください(図7)。

図7:「WriteableBitmapEffector」をインストールします(クリックで拡大)

インストールが完了すると、ソリューションエクスプローラー内の「参照の追加」内に、SoftbuildLibraryが追加されます。またSepiaImageプロジェクトの配下にpackage.configというファイルも追加されます。SoftbuildLibraryを削除して、再度Nugetからインストールしようとした時、package.configがあると、既にインストトール済みと認識されます。削除する場合は、このpackage.configも一緒に削除する必要があります。このSoftbuildLibrayのメソッドを使って画像をセピア調に変換します。
WriteableBitmapEffectorについては、下記のURLに使い方が掲載されています。
→ WriteableBitmapEffectorの使い方(酢ログ!)

各デバイスへのアクセス許可とピクチャライブラリへのアクセス許可

Webカメラにアクセスするには、ソリューションエクスプローラー内にある、Package.appmanifestをダブルクリックして開き、「機能」タブ内の「機能:」にある、「マイク」、「Webカメラ」にチェックを付けます。また作成されたXMLファイルをピクチャライブラリのサブフォルダに保存するため、「画像ライブラリ」にもチェックを付けておきます(図8)。

図8:デバイスへのアクセス、ピクチャライブラリへのアクセスを許可する(クリックで拡大)
薬師寺国安事務所

薬師寺国安事務所代表。Visual Basic プログラミングと、マイクロソフト系の技術をテーマとした、書籍や記事の執筆を行う。
1950年生まれ。事務系のサラリーマンだった40歳から趣味でプログラミングを始め、1996年より独学でActiveXに取り組む。1997年に薬師寺聖とコラボレーション・ユニット PROJECT KySS を結成。2003年よりフリーになり、PROJECT KySS の活動に本格的に参加、.NETやRIAに関する書籍や記事を多数執筆する傍ら、受託案件のプログラミングも手掛ける。Windows Phoneアプリ開発を経て、現在はWindows ストア アプリを多数公開中

Microsoft MVP for Development Platforms - Client App Dev (Oct 2003-Sep 2012)。Microsoft MVP for Development Platforms - Windows Phone Development(Oct 2012-Sep 2013)。Microsoft MVP for Development Platforms - Client Development(Oct 2013-Sep 2014)。Microsoft MVP for Development Platforms-Windows Platform Development (Oct 2014-Sep 2015)。

連載バックナンバー

Think ITメルマガ会員登録受付中

Think ITでは、技術情報が詰まったメールマガジン「Think IT Weekly」の配信サービスを提供しています。メルマガ会員登録を済ませれば、メルマガだけでなく、さまざまな限定特典を入手できるようになります。

Think ITメルマガ会員のサービス内容を見る

他にもこの記事が読まれています