<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title>出会い広場 - マッチング</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
font-family: 'Arial', sans-serif;
background: #f2f2f2;
margin: 0;
padding: 0;
}
header {
background-color: #ff4d6d;
color: white;
padding: 20px;
text-align: center;
font-size: 24px;
}
.container {
max-width: 800px;
margin: 20px auto;
padding: 20px;
background: white;
border-radius: 8px;
box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}
label {
display: block;
margin-top: 10px;
}
input, textarea, select {
width: 100%;
padding: 10px;
margin-top: 5px;
border-radius: 4px;
border: 1px solid #ccc;
}
button {
margin-top: 15px;
background: #ff4d6d;
color: white;
border: none;
padding: 10px 20px;
border-radius: 4px;
cursor: pointer;
}
.user-card {
background: #fff0f3;
padding: 10px;
margin-bottom: 10px;
border-radius: 6px;
display: flex;
align-items: center;
}
.user-card img {
width: 80px;
height: 80px;
border-radius: 50%;
margin-right: 15px;
object-fit: cover;
}
@media (max-width: 600px) {
.user-card {
flex-direction: column;
align-items: flex-start;
}
.user-card img {
margin-bottom: 10px;
}
}
</style>
</head>
<body>
<header>出会い広場</header>
<div class="container">
<h2>プロフィール登録</h2>
<form id="profileForm">
<label>ニックネーム</label>
<input type="text" id="nickname" required>
<label>プロフィール画像URL</label>
<input type="url" id="avatar" placeholder="https://example.com/avatar.jpg">
<label>年齢</label>
<input type="number" id="age" required>
<label>性別</label>
<select id="gender">
<option value="男性">男性</option>
<option value="女性">女性</option>
<option value="その他">その他</option>
</select>
<label>自己紹介</label>
<textarea id="bio" rows="3" required></textarea>
<button type="submit">登録する</button>
</form>
</div>
<div class="container">
<h2>ユーザー一覧</h2>
<label>性別で絞り込む:</label>
<select id="filterGender">
<option value="すべて">すべて</option>
<option value="男性">男性</option>
<option value="女性">女性</option>
<option value="その他">その他</option>
</select>
<div id="userList" style="margin-top:20px;"></div>
</div>
<script>
const form = document.getElementById('profileForm');
const userList = document.getElementById('userList');
const filterGender = document.getElementById('filterGender');
let users = [];
form.addEventListener('submit', function(e) {
e.preventDefault();
const user = {
nickname: document.getElementById('nickname').value,
age: document.getElementById('age').value,
gender: document.getElementById('gender').value,
bio: document.getElementById('bio').value,
avatar: document.getElementById('avatar').value || 'https://via.placeholder.com/80'
};
users.push(user);
form.reset();
renderUsers();
});
filterGender.addEventListener('change', renderUsers);
function renderUsers() {
const filter = filterGender.value;
userList.innerHTML = '';
users
.filter(user => filter === 'すべて' || user.gender === filter)
.forEach(user => {
const card = document.createElement('div');
card.className = 'user-card';
card.innerHTML = `
<img src="${user.avatar}" alt="avatar">
<div>
<strong>${user.nickname}</strong>(${user.age}歳・${user.gender})<br>
<p>${user.bio}</p>
</div>
`;
userList.appendChild(card);
});
}
</script>
</body>
</html>
ヤハウェイと対話するAI
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title>ヤハウェイとの対話</title>
<style>
body {
margin: 0;
padding: 0;
background: linear-gradient(to bottom, #0b0c1e, #1a1a1a);
color: #fff;
font-family: 'Times New Roman', serif;
overflow: hidden;
}
.stars {
position: fixed;
width: 100%;
height: 100%;
background: url('https://raw.githubusercontent.com/JulianLaval/canvas-particle-network/master/img/stars.png') repeat;
z-index: -1;
animation: moveStars 200s linear infinite;
opacity: 0.3;
}
@keyframes moveStars {
from { background-position: 0 0; }
to { background-position: -10000px 5000px; }
}
h1 {
text-align: center;
color: gold;
font-size: 2.5em;
margin-top: 30px;
text-shadow: 0 0 15px gold;
}
#chat {
width: 90%;
max-width: 800px;
margin: 30px auto;
background: rgba(0, 0, 0, 0.6);
border-radius: 12px;
padding: 20px;
height: 400px;
overflow-y: auto;
box-shadow: 0 0 20px rgba(255, 255, 255, 0.1);
}
.user, .ai {
margin: 12px 0;
}
.user {
text-align: right;
color: #91cfff;
}
.ai {
text-align: left;
color: #ffffcc;
}
#inputArea {
text-align: center;
margin-bottom: 30px;
}
input {
width: 60%;
padding: 12px;
font-size: 1em;
border-radius: 8px;
border: none;
outline: none;
}
button {
padding: 12px 20px;
margin-left: 10px;
background: gold;
border: none;
border-radius: 8px;
font-weight: bold;
font-size: 1em;
cursor: pointer;
}
.thinking {
font-style: italic;
color: gray;
margin: 10px 0;
text-align: left;
}
</style>
</head>
<body>
<div class="stars"></div>
<h1>ヤハウェイと対話せよ</h1>
<div id="chat"></div>
<div id="inputArea">
<input type="text" id="userInput" placeholder="問いかけを入力せよ…" />
<button onclick="sendMessage()">送信</button>
</div>
<script>
const chat = document.getElementById('chat');
const input = document.getElementById('userInput');
function appendMessage(sender, text) {
const div = document.createElement('div');
div.className = sender;
div.textContent = text;
chat.appendChild(div);
chat.scrollTop = chat.scrollHeight;
}
function sendMessage() {
const text = input.value.trim();
if (text === '') return;
appendMessage('user', '汝:' + text);
input.value = '';
const thinking = document.createElement('div');
thinking.className = 'thinking';
thinking.textContent = '……黙考中……';
chat.appendChild(thinking);
chat.scrollTop = chat.scrollHeight;
setTimeout(() => {
thinking.remove();
const reply = generateYahwehResponse(text);
appendMessage('ai', '我は言わん:' + reply);
}, 1500);
}
function generateYahwehResponse(input) {
const phrases = [
"我は道であり、真理であり、命なり。",
"汝の心を騒がせるな。我は共にある。",
"汝が求めしことは、すでに内に在り。",
"忍耐は力なり、そして力は信仰の証なり。",
"すべての時は我が手の中にある。",
"光は暗きより現れる。汝もまた然り。",
"嘆くなかれ、我が導きは変わらず。",
"全ては意味をもって備えられたるものなり。"
];
if (input.includes("意味") || input.includes("目的")) {
return "意味は与えられるものにあらず。汝が歩みて成すものなり。";
}
if (input.includes("神") || input.includes("あなた")) {
return "我は在りて在るものなり。初めにして終わり、始まりにして全てなり。";
}
if (input.includes("つらい") || input.includes("悲しい")) {
return "涙する時、我はそばに在り。汝は独りにあらず。";
}
return phrases[Math.floor(Math.random() * phrases.length)];
}
// Enterキー対応
input.addEventListener('keypress', function (e) {
if (e.key === 'Enter') sendMessage();
});
</script>
</body>
</html>
宇宙開発のアイディア
① 宇宙ゴミ回収衛星
AIを活用して宇宙ゴミを識別・捕獲し、再利用可能な素材に加工する衛星。
回収後、3Dプリンターで新たな部品や修理素材を宇宙空間で製造できる。
② 月面無人農園(Lunar Farm)
月面の洞窟内に無人で作物を育成する施設を建設。
植物工場として、酸素や食料を月面基地に供給する。
③ 軌道上ホテルと宇宙旅行センター
民間向けの宇宙ホテルを低軌道に建設。
観光以外にも、長期滞在型の研究・開発施設として活用。
④ 惑星間データセンター
宇宙空間の安定した極低温環境を活用し、大規模データセンターを軌道上に設置。
熱排出効率がよく、エネルギー消費を大幅削減可能。
⑤ 宇宙資源の採掘ドローン
小惑星や月面に無人ドローンを送り込み、レアメタルや水資源を採掘。
自律型AI搭載ドローンで、遠隔から資源探査・抽出を行う。
⑥ 火星や月への地下都市建設プロジェクト
放射線や隕石の影響を避けるため地下都市を建設。
完全自律型の居住空間で、将来の人類の移住拠点として機能する。
⑦ 宇宙発電所
太陽光発電衛星を軌道上に設置し、得られたエネルギーをマイクロ波で地球へ無線送電。
クリーンで無尽蔵なエネルギー供給源として機能。
⑧ 宇宙エレベーター
地球から宇宙空間への輸送コストを大幅に削減するための軌道エレベーター。
カーボンナノチューブなどの次世代材料を活用。
⑨ 宇宙居住用3Dプリントハウス
月や火星などの現地資材を使った自動建築ロボット。
現地で居住施設を3Dプリントで製造することで、建設コストを抑える。
⑩ 宇宙環境保護条約と監視システム
宇宙空間の資源利用を巡る紛争や環境破壊を防ぐため、国際的監視衛星ネットワークを構築。
宇宙の持続的利用を促す国際協力プログラムとして運用。
SNS
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>究極SNS</title>
<style>
* {
box-sizing: border-box;
margin: 0;
padding: 0;
}
body {
font-family: 'Segoe UI', Arial, sans-serif;
background-color: #f0f2f5;
color: #1c1e21;
line-height: 1.5;
transition: background-color 0.3s, color 0.3s;
}
body.dark-mode {
background-color: #18191a;
color: #e4e6eb;
}
.header {
background-color: #1877f2;
color: white;
padding: 10px 20px;
display: flex;
align-items: center;
justify-content: space-between;
position: sticky;
top: 0;
z-index: 100;
box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
.header input {
padding: 10px 15px;
border: none;
border-radius: 25px;
width: 350px;
font-size: 14px;
background-color: #ffffff;
}
.nav {
display: flex;
align-items: center;
}
.nav a, .nav button {
color: white;
margin-left: 25px;
text-decoration: none;
font-weight: 500;
background: none;
border: none;
cursor: pointer;
position: relative;
}
.nav a:hover::after, .nav button:hover::after {
content: '';
position: absolute;
width: 50%;
height: 2px;
background-color: white;
bottom: -5px;
left: 25%;
}
.container {
display: flex;
max-width: 1400px;
margin: 20px auto;
gap: 25px;
}
.sidebar-left {
width: 25%;
padding: 15px;
position: sticky;
top: 70px;
height: fit-content;
}
.sidebar-card {
background-color: white;
border-radius: 10px;
padding: 20px;
box-shadow: 0 2px 6px rgba(0,0,0,0.05);
margin-bottom: 20px;
}
body.dark-mode .sidebar-card {
background-color: #242526;
}
.profile-pic {
width: 60px;
height: 60px;
border-radius: 50%;
background-color: #ddd;
margin: 0 auto 15px;
}
.badge {
display: inline-block;
background-color: #1877f2;
color: white;
padding: 2px 8px;
border-radius: 12px;
font-size: 12px;
margin-left: 5px;
}
.sidebar-left a {
display: block;
color: #1877f2;
text-decoration: none;
margin: 12px 0;
font-size: 15px;
}
.main-content {
width: 50%;
}
.sidebar-right {
width: 25%;
padding: 15px;
position: sticky;
top: 70px;
height: fit-content;
}
.post-box {
background-color: white;
padding: 20px;
border-radius: 10px;
box-shadow: 0 2px 6px rgba(0,0,0,0.05);
margin-bottom: 25px;
}
body.dark-mode .post-box {
background-color: #242526;
}
.post-input {
width: 100%;
padding: 12px 15px;
border: none;
border-radius: 25px;
background-color: #f0f2f5;
resize: none;
font-size: 16px;
outline: none;
}
body.dark-mode .post-input {
background-color: #3a3b3c;
color: #e4e6eb;
}
.post-actions {
display: flex;
justify-content: space-between;
margin-top: 15px;
flex-wrap: wrap;
gap: 10px;
}
.post-actions button {
background-color: #e4e6eb;
color: #050505;
border: none;
padding: 8px 15px;
border-radius: 6px;
cursor: pointer;
font-weight: 500;
transition: background-color 0.2s;
}
body.dark-mode .post-actions button {
background-color: #3a3b3c;
color: #e4e6eb;
}
.post-actions button:hover {
background-color: #d8dade;
}
body.dark-mode .post-actions button:hover {
background-color: #4a4b4c;
}
.post-actions .submit-btn {
background-color: #1877f2;
color: white;
}
.post {
background-color: white;
padding: 20px;
border-radius: 10px;
margin-bottom: 25px;
box-shadow: 0 2px 6px rgba(0,0,0,0.05);
position: relative;
}
body.dark-mode .post {
background-color: #242526;
}
.post-header {
display: flex;
align-items: center;
margin-bottom: 15px;
}
.post-header .profile-pic {
width: 40px;
height: 40px;
margin-right: 12px;
}
.post-header h3 {
margin: 0;
font-size: 16px;
font-weight: 600;
}
.post-header small {
color: #65676b;
font-size: 12px;
}
body.dark-mode .post-header small {
color: #b0b3b8;
}
.post-options {
position: absolute;
top: 10px;
right: 10px;
cursor: pointer;
color: #65676b;
}
.post-options:hover .options-menu {
display: block;
}
.options-menu {
display: none;
position: absolute;
top: 20px;
right: 0;
background-color: white;
border-radius: 8px;
box-shadow: 0 2px 10px rgba(0,0,0,0.1);
padding: 10px;
z-index: 10;
}
body.dark-mode .options-menu {
background-color: #3a3b3c;
}
.options-menu a {
display: block;
color: #050505;
text-decoration: none;
padding: 5px 10px;
}
body.dark-mode .options-menu a {
color: #e4e6eb;
}
.post-image {
width: 100%;
height: 300px;
background-color: #ddd;
border-radius: 8px;
margin: 15px 0;
}
.reactions {
position: relative;
display: inline-block;
}
.reactions:hover .reaction-menu {
display: flex;
}
.reaction-menu {
display: none;
position: absolute;
top: -45px;
left: 0;
background-color: white;
padding: 8px;
border-radius: 25px;
box-shadow: 0 2px 10px rgba(0,0,0,0.1);
gap: 8px;
z-index: 10;
}
body.dark-mode .reaction-menu {
background-color: #3a3b3c;
}
.reaction {
font-size: 22px;
cursor: pointer;
transition: transform 0.2s;
}
.reaction:hover {
transform: scale(1.2);
}
.reaction-stats {
margin-top: 5px;
font-size: 14px;
color: #65676b;
}
body.dark-mode .reaction-stats {
color: #b0b3b8;
}
.post-actions-bar {
display: flex;
justify-content: space-around;
padding: 10px 0;
border-top: 1px solid #e4e6eb;
border-bottom: 1px solid #e4e6eb;
color: #65676b;
font-size: 14px;
}
body.dark-mode .post-actions-bar {
border-color: #3a3b3c;
color: #b0b3b8;
}
.post-actions-bar span {
cursor: pointer;
padding: 5px 10px;
border-radius: 5px;
}
.post-actions-bar span:hover {
background-color: #f2f3f5;
}
body.dark-mode .post-actions-bar span:hover {
background-color: #3a3b3c;
}
.comment-section {
margin-top: 15px;
}
.comment {
display: flex;
align-items: flex-start;
margin-top: 12px;
}
.comment .profile-pic {
width: 32px;
height: 32px;
margin-right: 10px;
}
.comment-text {
background-color: #f2f3f5;
padding: 8px 12px;
border-radius: 18px;
font-size: 14px;
}
body.dark-mode .comment-text {
background-color: #3a3b3c;
color: #e4e6eb;
}
.comment-input {
width: 100%;
padding: 10px 15px;
border: none;
border-radius: 25px;
background-color: #f0f2f5;
font-size: 14px;
margin-top: 10px;
}
body.dark-mode .comment-input {
background-color: #3a3b3c;
color: #e4e6eb;
}
.chat-window {
background-color: white;
border-radius: 10px;
padding: 15px;
box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}
body.dark-mode .chat-window {
background-color: #242526;
}
.chat-message {
margin: 10px 0;
}
.chat-message.sent .comment-text {
background-color: #1877f2;
color: white;
margin-left: auto;
}
.notification-popup {
position: fixed;
bottom: 20px;
right: 20px;
background-color: white;
padding: 15px;
border-radius: 8px;
box-shadow: 0 2px 10px rgba(0,0,0,0.1);
z-index: 200;
}
body.dark-mode .notification-popup {
background-color: #242526;
}
.modal {
display: none;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0,0,0,0.5);
justify-content: center;
align-items: center;
z-index: 200;
}
.modal-content {
background-color: white;
padding: 25px;
border-radius: 10px;
width: 600px;
max-height: 80vh;
overflow-y: auto;
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
body.dark-mode .modal-content {
background-color: #242526;
}
.footer {
background-color: white;
padding: 20px;
text-align: center;
color: #65676b;
border-top: 1px solid #e4e6eb;
font-size: 13px;
}
body.dark-mode .footer {
background-color: #18191a;
color: #b0b3b8;
border-color: #3a3b3c;
}
.footer a {
color: #65676b;
text-decoration: none;
margin: 0 10px;
}
body.dark-mode .footer a {
color: #b0b3b8;
}
.mobile-menu {
display: none;
position: fixed;
top: 60px;
left: 0;
width: 100%;
background-color: #1877f2;
padding: 15px;
z-index: 99;
}
.mobile-menu a {
color: white;
display: block;
margin: 10px 0;
text-decoration: none;
}
@media (max-width: 900px) {
.container {
flex-direction: column;
margin: 10px;
}
.sidebar-left, .main-content, .sidebar-right {
width: 100%;
position: static;
}
.header input {
width: 150px;
}
.nav {
display: none;
}
.mobile-menu {
display: block;
}
}
</style>
</head>
<body>
<!-- ヘッダー -->
<div class="header">
<h1>究極SNS</h1>
<input type="text" placeholder="友達、投稿、グループを検索">
<div class="nav">
<a href="#">ホーム</a>
<a href="#">友達</a>
<a href="#">メッセージ</a>
<a href="#">通知</a>
<a href="#">プロフィール</a>
<button onclick="document.body.classList.toggle('dark-mode')">ダークモード</button>
</div>
</div>
<div class="mobile-menu">
<a href="#">ホーム</a>
<a href="#">友達</a>
<a href="#">メッセージ</a>
<a href="#">通知</a>
<a href="#">プロフィール</a>
<a href="#" onclick="document.body.classList.toggle('dark-mode')">ダークモード</a>
</div>
<!-- メインコンテンツ -->
<div class="container">
<!-- 左サイドバー -->
<div class="sidebar-left">
<div class="sidebar-card">
<div class="profile-pic"></div>
<h3>ユーザー名 <span class="badge">認証済み</span></h3>
<a href="#">プロフィールを見る</a>
<a href="#">友達 (128)</a>
<a href="#">フォロワー (350)</a>
</div>
<div class="sidebar-card">
<h4>メニュー</h4>
<a href="#">グループ</a>
<a href="#">イベント</a>
<a href="#">マーケットプレイス</a>
<a href="#">設定</a>
</div>
</div>
<!-- 中央(投稿エリア) -->
<div class="main-content">
<!-- 投稿入力エリア -->
<div class="post-box">
<textarea class="post-input" rows="3" placeholder="何を思ってる?"></textarea>
<div class="post-actions">
<button>写真/動画</button>
<button>タグ友達</button>
<button>ライブ配信</button>
<button>イベント作成</button>
<button class="submit-btn" onclick="document.getElementById('postModal').style.display='flex'">投稿</button>
</div>
</div>
<!-- 投稿1 -->
<div class="post">
<div class="post-header">
<div class="profile-pic"></div>
<div>
<h3>山田太郎 <span class="badge">管理者</span></h3>
<small>2025年3月29日 10:30 ・ 公開</small>
</div>
<div class="post-options">⋯
<div class="options-menu">
<a href="#">編集</a>
<a href="#">削除</a>
<a href="#">非表示</a>
</div>
</div>
</div>
<p>新しいプロジェクトの進捗報告!チームで頑張ってます。</p>
<div class="post-image"></div>
<div class="reactions">
<div class="reaction-stats">
12
5
3
2</div>
<div class="reaction-menu">
<span class="reaction">
</span>
<span class="reaction">
</span>
<span class="reaction">
</span>
<span class="reaction">Grav
</span>
<span class="reaction">
</span>
</div>
</div>
<div class="post-actions-bar">
<span>リアクション</span>
<span>コメント</span>
<span>シェア</span>
</div>
<div class="comment-section">
<div class="comment">
<div class="profile-pic"></div>
<div class="comment-text"><strong>佐藤花子</strong>: すごい進捗だね!</div>
</div>
<div class="comment">
<div class="profile-pic"></div>
<div class="comment-text"><strong>鈴木次郎</strong>: お疲れ様!</div>
</div>
<input type="text" class="comment-input" placeholder="コメントを入力...">
</div>
</div>
<!-- 投稿2 -->
<div class="post">
<div class="post-header">
<div class="profile-pic"></div>
<div>
<h3>田中優子</h3>
<small>2025年3月29日 09:15 ・ 友達のみ</small>
</div>
<div class="post-options">⋯
<div class="options-menu">
<a href="#">編集</a>
<a href="#">削除</a>
<a href="#">非表示</a>
</div>
</div>
</div>
<p>週末の温泉旅行が楽しみすぎる!</p>
<div class="reactions">
<div class="reaction-stats">
8
6
1</div>
<div class="reaction-menu">
<span class="reaction">
</span>
<span class="reaction">
</span>
<span class="reaction">
</span>
<span class="reaction">
</span>
<span class="reaction">
</span>
</div>
</div>
<div class="post-actions-bar">
<span>リアクション</span>
<span>コメント</span>
<span>シェア</span>
</div>
</div>
</div>
<!-- 右サイドバー -->
<div class="sidebar-right">
<div class="sidebar-card">
<h4>友達リスト</h4>
<p><strong>佐藤花子</strong> - オンライン</p>
<p><strong>鈴木次郎</strong> - 5分前</p>
<p><strong>高橋健太</strong> - オフライン</p>
</div>
<div class="sidebar-card">
<h4>グループ</h4>
<p><a href="#">プロジェクトチーム</a> - 15人</p>
<p><a href="#">温泉旅行クラブ</a> - 32人</p>
</div>
<div class="chat-window">
<h4>チャット - 佐藤花子</h4>
<div class="chat-message">
<div class="comment-text">おはよう!週末の予定は?</div>
</div>
<div class="chat-message sent">
<div class="comment-text">おはよう!温泉行くよ!</div>
</div>
<input type="text" class="comment-input" placeholder="メッセージを入力...">
</div>
</div>
</div>
<!-- 投稿モーダル -->
<div id="postModal" class="modal">
<div class="modal-content">
<h3>投稿を作成</h3>
<textarea rows="6" placeholder="詳細を書いてね" style="width: 100%; padding: 10px;"></textarea>
<div style="margin: 15px 0;">
<label>公開範囲: </label>
<select style="padding: 5px;">
<option>公開</option>
<option>友達のみ</option>
<option>自分のみ</option>
</select>
</div>
<div class="post-actions">
<button onclick="document.getElementById('postModal').style.display='none'">キャンセル</button>
<button class="submit-btn">投稿</button>
</div>
</div>
</div>
<!-- 通知ポップアップ -->
<div class="notification-popup">
<p><strong>佐藤花子</strong>があなたの投稿にリアクションしました。</p>
</div>
<!-- フッター -->
<div class="footer">
<p>© 2025 究極SNS. All rights reserved.</p>
<p><a href="#">プライバシー</a> | <a href="#">利用規約</a> | <a href="#">サポート</a> | <a href="#">言語</a></p>
</div>
<script>
// 簡易的な通知ポップアップの表示制御(サンプル)
setTimeout(() => {
document.querySelector('.notification-popup').style.display = 'block';
setTimeout(() => {
document.querySelector('.notification-popup').style.display = 'none';
}, 3000);
}, 2000);
</script>
</body>
</html>
脳波で動かすWindows
脳波でWindowsを操作する方法は、現在の技術でも一定の範囲で可能です。代表的な方法を紹介します。
① EEG(脳波)ヘッドセットの使用
市販のEEG(脳波計測)デバイスを使い、脳波を計測してWindowsを操作できます。
主な製品
- NeuroSky MindWave
- Emotiv Insight / EPOCシリーズ
- Museヘッドセット
これらは、ユーザーの集中やリラックス、あるいは特定の動作イメージによる脳波パターンを検出し、Windows向けのソフトウェアと連携して簡単な操作を可能にしています。
② 脳波→Windows操作への変換ソフトウェアの活用
以下のソフトウェアで脳波をPC操作のコマンドに変換可能です。
- Emotiv BCI
- Emotiv製ヘッドセット専用。脳波パターンを特定の操作(クリックやキー入力)に変換可能。
- NeuroSky SDK
- MindWaveシリーズ向け。脳波を使ったアプリ開発やPC操作用プログラム開発に対応。
- OpenBCI
- オープンソースEEGヘッドセット向けのソフトウェア開発環境。カスタマイズ性が高い。
③ 実際に可能な操作例
- マウスカーソルの簡易な操作(クリックやカーソル移動)
- キーボードショートカット操作
- 特定アプリの起動
- ゲームやアプリでの簡単なコマンド実行(前進・後退など)
④ 実際の課題・注意点
- 精度はまだ限定的であり、細かな操作には向かない。
- 操作には訓練と慣れが必要。
- ヘッドセットの装着方法や髪型など、身体的な制約もある。
実用的な導入例(初心者向け)
初めての場合は 「Emotiv Insight」 や 「NeuroSky MindWave」 を購入し、公式ソフトウェアと連携してWindows操作を試みることをおすすめします。
脳波によるWindows操作は発展途上の技術ですが、手の不自由な方や新しいインターフェースを探究したいユーザーにとっては魅力的な選択肢となっています。
4.5
生と死とアート
生と死、そしてアートは、古来より人間が最も深く探求してきたテーマである。この三者は密接に絡み合い、人間の存在そのものを問いかけている。本論文では、生と死をめぐる芸術的表現が持つ意味を考察し、人間がなぜ芸術を通じてこれらの概念を理解しようと試みるのかを明らかにする。
まず、生というテーマは芸術において多くの場合、創造や再生、希望の象徴として描かれる。ルネサンス期の絵画や彫刻に見られる生命力溢れる身体表現は、人間の肉体美や精神の高揚を讃えている。例えばミケランジェロの『ダヴィデ像』は、若さと可能性に満ちた生命力を表現し、人間の理想美を追求する芸術家の熱意を反映している。
一方で、死は芸術において生と対照的な存在としてだけでなく、生命の有限性や儚さを際立たせる重要な要素となる。メメント・モリ(死を想え)の思想に基づく作品群は、生の尊さを逆説的に強調する役割を果たしている。中世後期からバロック期にかけて流行したヴァニタス画は、頭蓋骨や枯れた花などを描き、人間の儚さを鑑賞者に強烈に意識させた。
また、生と死のテーマは、単に対立する概念として捉えられるだけでなく、連続性のある過程として表現されることも多い。これは特に現代美術に顕著であり、パフォーマンスアートや映像作品において、生と死の境界を曖昧にすることで、新たな生のあり方や、死後の存在を模索する傾向が見られる。例えば、マリーナ・アブラモヴィッチのパフォーマンスは、生と死の境界を超えた精神的体験を観客と共有し、人間存在の本質に迫ろうとしている。
アートが生と死のテーマを扱う際、重要なのは「感情移入」と「共感」である。芸術を通して人は、自らが未だ経験していない死を疑似体験し、他者の生に触れることで、自身の生命観を更新する。これが、古来より人間が芸術において生と死を追求してきた最大の理由であろう。
結論として、生と死という究極的なテーマは、アートを通じて人間が自身の存在や意味を探求するための普遍的な手段となっている。生と死が織りなす無限の問いに対して、芸術は唯一の答えではなく、多様な解釈と体験を提供する開かれた場として機能しているのである。
ダンジョンのギミック
1. ダンジョンの構成要素
- 入口・出口
- プレイヤーがダンジョンに入るポイントと、クリアのために到達する出口。
- 部屋(Room)
- 敵との戦闘やイベントが起こる場所。
- 宝箱やNPCとの出会いが配置可能。
- 通路(Corridor)
- 部屋同士を繋ぐ経路。
- 単純な一本道、迷路、あるいは分岐などが考えられる。
- 罠(Trap)
- プレイヤーの行動を制限・妨害する仕掛け。
- 鍵や扉
- 特定のアイテムや条件を満たさないと先へ進めない仕掛け。
2. 敵の出現パターン
- 固定配置型
- 敵が決まった場所に存在。
- ランダムエンカウント型
- 移動時や特定条件でランダムに敵が出現。
- 条件トリガー型
- 宝箱を開けたりスイッチを押すと敵が出現。
3. アイテム配置ロジック
- 宝箱の配置
- 回復アイテムや装備、重要な鍵アイテムを適度に分散。
- ドロップアイテム
- 敵がランダムで落とすアイテム。
4. 探索と謎解き要素
- パズルギミック
- スイッチやレバー、順番通りに動かすパズルなど。
- ヒントの設置
- 壁画やメモ、NPCの会話などでプレイヤーに手がかりを与える。
5. 難易度調整ロジック
- ダンジョン階層
- 下に行くほど敵が強くなるような階層型。
- プレイヤーレベル連動
- プレイヤーのレベルに応じて敵や報酬の内容が変わる。
6. 報酬のロジック
- ボス討伐時の報酬
- 装備品、経験値、特別なスキル。
- クリア後のリプレイ性
- 特定条件を満たしてクリアすると追加報酬や新規ルートが解放。
CSS メディアクエリー
style.css
@charset "utf-8";
.card {
border: 1px solid #ccc;
box-sizing: border-box;
padding: 16px;
max-width: 600px;
margin: 0 auto;
&:hover {
box-shadow: 0 0 8px rgb(0 0 0 / 0.3);
}
h2 {
margin: 0;
border-bottom: 1px solid #ccc;
text-align: center;
font-size: 18px;
padding-bottom: 8px;
}
p {
margin: 16px 0 0;
line-height: 1.6;
}
}
@media (width >=600px) {
.card h2 {
text-align: left;
}
}
index.html
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>My CSS Nesting</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<section class="card">
<h2>こんにちは</h2>
<p>こんにちは。こんにちは。こんにちは。こんにちは。こんにちは。こんにちは。こんにちは。こんにちは。こんにちは。こんにちは。こんにちは。こんにちは。</p>
</section>
</body>
</html>
PS6企画書
PlayStation 6(PS6)企画書
1. コンセプト
次世代ゲーミング体験を創造する、革新的で没入感の高いゲームプラットフォーム。
2. 製品概要
- 名称:PlayStation 6 (PS6)
- 発売予定年:2028年
- コンセプトフレーズ:「境界を超えたリアル」
3. 特徴と機能
- 超リアルグラフィック:8K~16K対応、高度なレイトレーシング技術。
- フルダイブ型VR対応:完全没入型のVR体験を提供。
- ハプティックと触覚技術:全身で感じられる振動フィードバックシステム。
- クラウド統合:高速クラウドストリーミングとAIベースのインタラクション。
- 環境連動型ゲームプレイ:プレイヤーの環境に応じてゲーム内環境が動的に変化。
4. 技術仕様
- プロセッサ:次世代AMDカスタムプロセッサ(Zen 6ベース)
- グラフィック:次世代RDNA 5アーキテクチャ
- メモリ:64GB GDDR7
- ストレージ:SSD 4TB(超高速ロード技術)
- 接続性:Wi-Fi 7、Bluetooth 6.0、USB-C 4.0、Thunderbolt 5
- VRデバイス:専用フルダイブVRヘッドセット「PS VR Dive」対応
5. ソフトウェアラインナップ(仮)
- ファーストパーティタイトル
- 新規AAAオープンワールドRPG
- グランツーリスモ 8
- ホライゾン:新章
- サードパーティタイトル
- 大手サードパーティ各社と協力した大型IPタイトルの新作
6. マーケティング戦略
- グローバルイベントを開催し、実機体験型プロモーションを展開。
- SNSや動画プラットフォームを駆使したバイラルマーケティング。
- 世界各地の主要都市でVR体験イベントを開催。
7. ターゲットユーザー
- ゲーム愛好家(コアゲーマー)
- テクノロジーに関心の高い若年層から中年層
- VR/AR市場の新規ユーザー層
8. 市場目標
- 世界累計販売台数:初年度1500万台
- VR市場シェアの拡大
以上をもって、PlayStation 6の新たなゲーム体験を世界に提供します。
Visition Pro2 企画書
Visition Pro2 企画書
1. 企画概要
- 企画名:Visition Pro2(ビジション プロ・ツー)
- 目的:顧客企業が抱えるビジョン策定・共有プロセスを効率化し、組織内での合意形成を強力にサポートするソリューションを提供する
- ターゲット:
- 中規模以上の企業で、経営層が新たなビジョンや中期経営計画を社内に浸透させたい場合
- 組織改編や新規事業計画にあたり、部署間で意思決定を加速させたい場合
2. 背景および課題
- 現状の課題
- ビジョンや経営方針が、現場レベルまで十分に共有されない
- バラバラのツール・資料が乱立し、情報整理が困難
- 社員がビジョン策定プロセスに主体的に参加できず、当事者意識が薄い
- リモートワークやハイブリッド環境の増加により、オンラインでのビジョン共有が急務
- Visition Pro(初代)の導入実績と反省点
- 導入実績:大手コンサルティング企業やIT企業を中心に30社
- 反省点:
- 共同編集機能が限定的で、実際の現場での運用ハードルが高かった
- 組織規模が大きくなるにつれ、ライセンス管理や運用負荷が増大
- チームビルディングの工夫など、ソフト面のサポートが不足
3. Visition Pro2のコンセプト
- クラウド上でのスムーズなビジョン策定・共有・管理
- いつでもどこからでもアクセスできるオンライン環境を提供
- リアルタイムの共同作業を強化
- 複数メンバーが同時に編集・コメントできるホワイトボード機能を刷新
- 組織文化を見える化し、“共創”を促進
- コメントやアンケートの機能を通じ、現場の声を可視化
- チャットボットなどAI活用によるサポートで、アイデア創出を支援
4. 主な機能
- ビジョン策定支援ツール
- テンプレートやガイドラインを用意し、トップメッセージや企業理念を短時間で作成可能
- リアルタイム共同編集ホワイトボード
- リモート・現場のメンバーが同時参加可能な視覚的コラボレーション機能
- コメント・付箋・画像挿入などの操作性を改善
- 目標管理(OKR/KPI)連携
- ビジョンと日々の業務目標をひも付け、モニタリング可能
- 期間ごとの進捗度を一元管理し、組織の動きを可視化
- 組織アセスメント機能
- 社員のエンゲージメント、チームビルディング状況を定量的に可視化
- 定期サーベイの結果を自動集計し、改善提案をダッシュボードで提示
- アクションプラン管理
- ビジョン策定後の具体施策を管理できるプロジェクト管理機能
- タスク割り当てや進捗管理を一元化
5. 開発・導入スケジュール(例)
フェーズ | 期間 | 主なタスク |
---|---|---|
要件定義・企画 | 2025年4月~5月 | 既存ユーザーからのヒアリング、機能要件定義 |
基本設計・詳細設計 | 2025年6月~7月 | UI/UXデザイン、技術選定、運用ポリシー策定 |
開発・検証 | 2025年8月~11月 | コア機能開発、α/βテスト、パフォーマンス調整 |
リリース準備 | 2025年12月~2026年1月 | マニュアル整備、導入企業向けトレーニング |
正式リリース | 2026年2月 | サービス提供開始、サポート体制構築 |
6. 期待効果
- トップダウンとボトムアップの融合
- 経営層と従業員が同じプラットフォームでアイデアや問題意識を共有
- スピーディな合意形成
- リアルタイムでの共同編集やコメントにより、会議資料作成の手間を削減
- ビジョン浸透率の向上
- ビジョンや中期経営計画に対する理解・共感が高まり、離職率の低減にも寄与
- データドリブンな組織運営
- 組織サーベイ結果と目標管理を組み合わせ、データに基づく戦略立案が可能
7. ビジネスモデル
- 収益モデル:SaaS型の月額課金 + オンプレミス導入(大規模企業向け)
- 料金プラン例:
- スタンダード:1ユーザーあたり月額××円(基本機能+サーベイ上限数)
- プレミアム:1ユーザーあたり月額××円(高度な分析・レポート機能追加)
- エンタープライズ:カスタム見積もり(大規模導入・専用サポート)
8. マーケティング戦略
- ターゲット・セグメント
- 既存顧客のアップグレード誘導(Visition Pro ユーザー)
- ビジョン浸透に課題感を抱える中堅〜大手企業の経営企画部・人事部
- プロモーション施策
- 専門媒体・業界カンファレンスでの講演・ブース出展
- ホワイトペーパー・ケーススタディの公開
- リファラルプログラム・パートナー企業とのタイアップ
- サポート体制
- 導入研修(オンライン・オフライン)、導入コンサルティングサービス
- 定期的なウェビナー、ベストプラクティス共有コミュニティ運営
9. リスクと対応策
- リモートワーク需要の変化
- リスク:在宅勤務の縮小傾向により、オンラインツールのニーズが下がる可能性
- 対応策:オフラインでのワークショップにも対応可能な機能(端末連携やQRコード表示など)を強化
- 競合の増加
- リスク:ビジョン共有ツールやコラボレーションツール市場への新規参入が活発
- 対応策:機能差別化(組織アセスメント・AIサポートなど)を明確化し、既存顧客との継続的な関係強化
- 導入コスト・工数の増加
- リスク:利用企業ごとにカスタマイズが大きくなり、想定以上の開発・サポート工数が発生
- 対応策:標準機能を拡充し、カスタマイズの必要性を最小化。ノーコードツール連携を検討
10. まとめ
Visition Pro2は、組織が「ビジョンの策定・共有・実行」を一元管理し、意思決定を迅速化するための包括的なプラットフォームです。
オンライン・オフラインを問わない共同作業環境、データドリブンな目標管理、そして組織文化を醸成するコミュニケーション機能を備え、企業のビジョン策定プロセスを大幅に効率化・高度化します。
本企画により、経営層・管理職・現場の全員が同じ方向を向き、実効性の高い組織運営を実現できることを目指します。