Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Portapad紹介プレゼンテーション
Search
Povo43
August 15, 2025
Programming
170
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Portapad紹介プレゼンテーション
u22プログラミングコンテスト一次審査用の動画に使用するプレゼンテーションです。
出来がいいのでアップロードします。
Povo43
August 15, 2025
More Decks by Povo43
See All by Povo43
人はなぜ愚かであるのか。
gotoumakakeru
0
14
Other Decks in Programming
See All in Programming
脅威をエンジニアリングの糧にして――現場編 / Turning Threats into Engineering Fuel — Field Edition
nrslib
0
300
技術記事、 専門家としてのプログラマ、 言語化
mizchi
13
6.5k
1B+ /day規模のログを管理する技術
broadleaf
0
110
さぁV100、メモリをお食べ・・・
nilpe
0
150
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
3
2.2k
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
390
「AIで開発し、AIを届ける」をEvalでつなぐ 〜AIネイティブに始めるプロダクト開発の実践〜 / Connecting "Develop with AI, deliver AI" with Eval
rkaga
4
5.4k
代数的データ型って何が嬉しいの? #frontend_phpcon_do
kajitack
8
3.8k
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
150
Inside Stream API
skrb
1
770
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
740
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.7k
Featured
See All Featured
A designer walks into a library…
pauljervisheath
211
24k
Agile that works and the tools we love
rasmusluckow
331
22k
Embracing the Ebb and Flow
colly
88
5.1k
Designing for humans not robots
tammielis
254
26k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3.2k
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
508
140k
My Coaching Mixtape
mlcsv
0
150
How STYLIGHT went responsive
nonsquared
100
6.2k
HTML-Aware ERB: The Path to Reactive Rendering @ RubyCon 2026, Rimini, Italy
marcoroth
1
230
Claude Code のすすめ
schroneko
67
230k
We Have a Design System, Now What?
morganepeng
55
8.2k
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
Transcript
ニッチで便利なインプット。
Portapadとは? Portapadは、スマホのブラウザからPCを操作すること ができる「手軽に」をコンセプトとした遠隔操作用の ソフトウェアです。
制作背景
制作背景 ①ガジェットの代用 「ペンタブレットは高価で買いにくい」という問題を解決するた めに、手持ちの機器で代用できないかと考えました。
制作背景 ②めんどくさい ①の問題を解決するために、ほかの団体や個人が作ったソフトも 使用してみましたが、インストール操作や認証処理が複雑で、め んどくさがり屋の僕には使うことが億劫だったので「簡単な操 作」を求めてPortapadを制作しました。
制作背景 ③自由度が低い 僕が試した既存のソフトは自由度が低かったです。 自由度はそのまま操作性に直結すると考えているので、webアプ リという形をとることで、リアルタイムでの機能追加が容易であ ると考え、この形式にしました。
液晶画面で代用 様々なUIを制作できる より「面白い」操作方法や、「欲しい」と思った機能が実装可能に
システム構成
システム構成 ホストとクライアントのWebRTC接続をする ためのSDPやIDEを仲介するサーバー シグナリングサーバー クライアントからのWebRTC経由での操作指 示に基づき、マウス・キーボードを操作する ホストPC タッチ操作を解析し、PCへ操作指示を出す。 クライアント WebSocket
WebRTC 全体の概要
システム構成 ホスト 設定画面 本体 接続とWebRTC通信 主にクライアントとの通信、それの制御を行います。 一時的なコードと永続的なコードを分けることで、セキュリティ性能 やユーザーの操作性が向上しました。 また、自動再起動などのエラー処理を確実に行うことにより高信頼性 を保っています。
Enigoによるデバイス操作 クライアントから受信したコードを識別し、操作を読み取り実際に操 作します。 低レベル処理は、安定性・安全性を考え、外部ライブラリに依存しま した。 遅延を最小限に抑えるため、可能な限り処理を軽量化しています。例 えば、通信にJSONを使わず、「mm1923,1002」のようなシンプルな 文字列形式で送受信し、それを分解して操作を行うことで、変換時の 遅延を抑える工夫をしています。 高速化 安定性 & 設定画面は、クライアント側のほうが操作の比重が大きいため、PCサ イドでしか設定できない内容のみに絞って配置しています。 &アピールポイント
システム構成 クライアント 接続処理 WebSocketでホストの一覧を取得し、 リスト表示にしています。 又、設定画面はここに統合されています。 認証処理 後述するed25595を使用した認証処理で す。 カメラを使用することで人為的なミスを
減らし、接続処理の簡略化に努めていま す。 操作画面 操作性に直結するためUIは作りこまれて います。 現在はトラックパッドとテンキーのみで すが将来的にキーボードやその他のニッ チなUIを実装する予定
システム構成 クライアント FetchAPI JavaScript modules × シンプルで高速な ページ移動 &アピールポイント
システム構成 セキュリティ ed25519 P2P接続 × Ed25519は、楕円曲線デジタル署名アルゴリズムの一種で、高い安全性と効率性があります。 P2P接続は、中央集権的なサーバーを介さず直接通信するため、 特定のサーバーにデータが収集されることはありません。 なりすまし耐性 耐障害性
通信の秘密 プライバシー保護 機密性 通信の秘密 &アピールポイント