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
KAKERU
August 15, 2025
Programming
1
110
Portapad紹介プレゼンテーション
u22プログラミングコンテスト一次審査用の動画に使用するプレゼンテーションです。
出来がいいのでアップロードします。
KAKERU
August 15, 2025
Tweet
Share
Other Decks in Programming
See All in Programming
それ CLI フレームワークがなくてもできるよ / Building CLI Tools Without Frameworks
orgachem
PRO
17
3.8k
JetBrainsのAI機能の紹介 #jjug
yusuke
0
200
Android 15以上でPDFのテキスト検索を爆速開発!
tonionagauzzi
0
200
新しいモバイルアプリ勉強会(仮)について
uetyo
1
250
Dart 参戦!!静的型付き言語界の隠れた実力者
kno3a87
0
190
あまり知られていない MCP 仕様たち / MCP specifications that aren’t widely known
ktr_0731
0
240
Claude Code と OpenAI o3 で メタデータ情報を作る
laket
0
110
decksh - a little language for decks
ajstarks
4
21k
Reactの歴史を振り返る
tutinoko
1
180
構文解析器入門
ydah
7
2.1k
LLMOpsのパフォーマンスを支える技術と現場で実践した改善
po3rin
2
460
リッチエディターを安全に開発・運用するために
unachang113
1
370
Featured
See All Featured
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
What's in a price? How to price your products and services
michaelherold
246
12k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
Practical Orchestrator
shlominoach
190
11k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
36
2.5k
Java REST API Framework Comparison - PWX 2021
mraible
33
8.8k
Docker and Python
trallard
45
3.5k
What’s in a name? Adding method to the madness
productmarketing
PRO
23
3.6k
We Have a Design System, Now What?
morganepeng
53
7.7k
Done Done
chrislema
185
16k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
16k
Embracing the Ebb and Flow
colly
86
4.8k
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接続は、中央集権的なサーバーを介さず直接通信するため、 特定のサーバーにデータが収集されることはありません。 なりすまし耐性 耐障害性
通信の秘密 プライバシー保護 機密性 通信の秘密 &アピールポイント