250
177

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

※サービス終了しました【ユーザー10万人超えの個人開発】「自分の声」が嫌いな人ほど使ってほしい!声成分分析サービス『Voice component』を作りました!

Last updated at Posted at 2021-07-15

はじめに

突然ですが、ご自身の声は好きですか?嫌いですか?
ちなみに私自身は後者です。理由は男なのに声が高くて電話でよく女性に間違われるからです笑
ふとそんな話を通っているスクールで話したところ男性・女性問わず「自分の声」が嫌い・苦手と思っている方が意外と多いことが分かりました。調べてみると、下記の一般向けに行われた調査データのように自分の声が好きと答えた人は約3割なのに対して、自分の声が嫌いと答えた人は約7割と圧倒的に多いということが分かります。(データ情報古いですが・・・)
参考: あなたは「自分の声」が好き? 嫌い?

声は生まれ持ったもので変えることはできません。その為、今「自分の声」が嫌い・苦手だと感じている人に向けて声を好きになれるきっかけを与えられるサービスを提供できないかと思ったのが作成のきっかけです。

サービス概要

PC・タブレット・スマホでご利用いただけます。

簡単5秒でユーザーの声を分析し、その声に似た有名人を表示してくれるサービスです。

使い方

簡単2ステップです。
トップページより
1. ”さっそく声の成分をチェック”ボタンをクリックし、5秒間声を録音
2. ”分析結果を確認する”ボタンをクリックする

デモ動画

e41b2aa024bfd2256c47898c1c9e8e12.gif

Q.このサービスを利用して本当に「自分の声」を好きになるの?

A.必ず好きになります

下記がその理由です。

  • 分析結果が期待以上だった場合(例.福◯雅治とか新◯結衣が出る)
    → 周囲に自慢していただき承認欲求を満たすことができます。

  • 分析結果が期待にそぐわない場合(例.ク◯ちゃんとかマツ◯ばっかり出るとか)
    → 開き直ってネタにできます。笑い話にすることでそのユーザーにとって新たな道が開けます。

**要するにどっちの結果に転んでも自分の声がネタになるので、**なんか自分の声悪くないかもー!と思えてきていつの間にか自分の声が好きになる!!という未来が確約されるも同然な訳です。

(なお異論は大いに認めます)

主な使用技術

  • Ruby 3.0.0
  • Rails 6.1.3
  • Vue.js 2.6.1
  • Highcharts
  • Capistrano
  • AWS(VPC,EC2,RDS,ALB,Route53,ACM)

外部API

Microsoft Speaker Recognition 「話者識別」

このサービスのメイン部分といっても過言ではありません。使っていただいたユーザーの方より声ってどういうロジックで処理しているのか知りたいという意見がちらほらあったのですが、すみません、私もそこの詳しい処理は分かりません笑
というのも、このAPIに声のデータを事前に登録しておいて、判別させたい声のデータを送ると、レスポンスとして声成分の一致度が高い順にデータを返してくれるという処理を行なってくれている為です。とても便利・・・
参考: Speaker Recognition とは

ちなみにこのAPI、実装記事がほとんどなく、ドキュメント頼みでした。(基本的にはドキュメント見て進めるとは思うので当たり前なのですが) しかしドキュメント通りにやっても上手くいかないこともあり(開発者ページの質問回答にドキュメントの修正内容が書いてあることもありました)、かつ外部APIを使うのが初めてだったので使いこなすまでに1ヶ月近くかかったのはここだけの話・・・

工夫した点

直感ですぐ使えるデザインを意識

ユーザーが直感ですぐ使えるよう、トップページでほぼ完結できるようなデザインを心掛けました。また現状の仕様ではユーザー登録・ログイン機能は必要ないと判断し、実装しませんでした。
2b8d722b01667303f604f27992cfa064.png

分析結果の表示

ユーザーに繰り返し使ってほしいという思いから、使う都度結果がある程度異なるよう、APIに登録している音声データは推奨時間よりも短くしています(あえて精度を落としてます)。

1回目
1回目.png
2回目
2回目.png

現状の使用したユーザーからの改善・要望案(随時対応予定)

録音中に何喋っていいのか分からない(2021.7.18改善済み)

ユーザーより音声録音時に何を話していいか分からないとの声を複数いただきました。修正前は5秒間声を録音するという指定だけでした。

(改善前)
846d62b54b8883f5bcbd4256d4410ee5.png

(改善後)
bfd0c03196e2176a2c4941694cb45c14.png
ユーザーが何を話すか分からない場合のアドバイスを一言追記。またアドバイスの種類は5種類ランダムで表示されるようにしました。

分析結果で出てきた名前をクリックするとGoogle検索画面に飛んで検索できるようにして欲しい

使用しているユーザーの方で分析結果で出てきた人を知らないという意見があったので、分析結果の名前をクリックするとGoogle検索でその名前の人物を検索できるなどの実装を考えたいと思います。
75f83bc7453cbbfa8d7414691e6e6589.png

分析結果をツイートした際に分析結果を画像で表示にしてほしい

現状は分析結果を文字でツイートできるようにしています。ただ他の診断系のサービスの場合、画像で診断結果をツイートできることが多いと思うので将来的には分析結果を画像でツイートできるように実装考えたいと思います。
d53953d487a537eabb663488b55a202a.png                       

         

今後追加してみたい機能(2021.7.19一部追加済み)

分析結果で表示される人物のレパートリーを増やす(追加済み)

現状は30人弱登録しているのですが、50人程度には増やしたいと考えています。
20人追加、計50人登録完了しました。なおAPIの登録上限が50人のようなので今後は適宜データの入れ替えを行っていきます。

真似したい有名人の声を選択してどれだけ似てるか数値で表示させる

ユーザーから要望があり、サービスの幅が広がりそうだと思いましたので実装方法考えます。

終わりに

昨年の11月から本格的にRailsの学習を始め、このサービスが私にとって初めてのアプリ制作でした。内容はシンプルだと思いますが、作れるアプリではなく、自分が作りたいアプリを作り、リリースするという目標を達成出来たことにまずはほっとしています。ありがたいことにリリースしてから既に様々なユーザーの方に使っていただき、フィードバックも多くいただいております。今後はユーザーにリピートして使っていただくということが最大の課題になるかと思うのでユーザーに飽きられないような機能の実装に努めたいと思います。

twitterアカウント
https://twitter.com/yama2_0506

私が通っていたスクール(現場を意識したカリキュラムの難易度・運営側の手厚いサポート・コミュニティの活発さ どれをとってもオススメしたいスクールです。未経験でこれからスクール入学を検討されている方は是非!)
https://runteq.jp/

(追記)2022.6.14 リリース約1年経ち、でユーザー数10万人超え、PV数11万を突破!

リリースから約1年が経ち、新機能の追加などしばらく出来ていないのですが、ありがたいことに未だにユーザーの方にちょくちょく使っていただけているおかげで気づけば上記を達成することが出来ました!本当に多くの方々に使っていただき感謝しかないです!

(追記)2023.3.2 サービス終了のお知らせ

サービス開始から1年半近くが経ち、本業との兼ね合いで中々運用・改善が進まずこれ以上の運用は厳しいと判断し、サービスを終了させていただきました。サービスをご利用いただいた方々、誠にありがとうございました!

250
177
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
250
177

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?