data:image/s3,"s3://crabby-images/33e7d/33e7d9f6049e8ae98b8e54448d889d0562034678" alt="見出し画像"
埋め込みアナログ時計をAIで生成!ーGoogleサイトで作るグループウェア(145)ー
🙇🏻いつも、Googleサイトで作るグループウェアを見ていただき、ありがとうございます!
この記事を読んで欲しい方
企業DXや校務DXの進め方に悩んでいる方
クラウドアプリの導入に悩んでいる方
自分だけのGoogleサイトを作ってみたい方
①久しぶりにGoogleサイトネタです
久しぶりにGoogleサイトネタ?になります。ただし、AIを使って、埋め込みコード用のアナログ時計を作っていきます。
実は、このアナログ時計はGemini1.5proやChatGPT4oではうまく作れませんが、新しくでたばっかりのClaude3.5Sonnetではきちんと作れたので、そのご報告も兼ねて作成しています。
アナログ時計をつくらせるプロンプトは、
アナログ時計をJavascript、HTML、CSSでつくってください。
ただしGoogleサイトに埋め込むため、すべてHTMLで作成してください。
で、作られたHTMLをGoogleサイトに埋め込んで検証します。
②Gemini1.5pro
まず有料2900円のGeminiAdvanceのGemini1.5proからです。プロンプトを実行し、作られたHTMLをGoogleサイトに埋め込みます。
data:image/s3,"s3://crabby-images/bbd26/bbd26cbfae8ed50f1bc8e096c6745cddd1b4dbcf" alt=""
data:image/s3,"s3://crabby-images/179fe/179fe6b3cb44ac66c2cde0a123fb66d50242b394" alt=""
はい、Geminiはだめですね。ここからいくら指示を出しても完成することはありませんでした。
data:image/s3,"s3://crabby-images/e46c8/e46c86c5d4e59dea58c02e02b55614baa9f23a9c" alt=""
③Chat-GPT4o
同様に、有料$20のChat-GPT4oでプロンプトを実行します。
data:image/s3,"s3://crabby-images/b86a5/b86a58d002c6752f00ffc28e2c684d4445b02894" alt=""
さっきのGeminiよりもまともに作れました。
でもなんだか不格好(針の長さがみなおなじ)ですし、Gemini同様ここから細かく指示を出しても完成しませんでした。
data:image/s3,"s3://crabby-images/97436/9743674ccb75b17d309a9128708b1db135740860" alt=""
④Claude3.5Sonnet見参!
はい、出たばかりのClaude3.5Sonnetに、同様にプロンプトに貼り付けて実行します。
data:image/s3,"s3://crabby-images/cfa1a/cfa1a1b5a9ab0a01942e6da6bf1c32c17164557e" alt=""
おっ!いきなり、きれいにできていますね!ワクワク!
data:image/s3,"s3://crabby-images/43948/4394829df2d2d2dc01ecf1f336417650ea4db387" alt=""
⑤文字盤をいれる
Claude3.5Sonnetがちゃんとできているようなので、これを土台にして、文字盤を入れます。
文字盤に数字をすべて入れてください
はい、いいかんじにできてのですが、ちょっと数字が時計の外枠に近いですね。
data:image/s3,"s3://crabby-images/9042f/9042f0f05e1bba7a200698b4f54c50f4da525756" alt=""
ここで、色々試行錯誤をしていたのですが、なんと活動限界が来てしまいました。
data:image/s3,"s3://crabby-images/61b41/61b41d7923fe25757cc4a9cdc2848ca514441ccb" alt=""
現在、Claudeの有料$20のProプランを使っているのですが、あまり試行錯誤しすぎると有料でも駄目なようです。
FAQには、Pro版のプロンプトはFree版の5倍までで、なるべくまとめて入れてくれと書いてありました。(有料版でも5時間で45メッセージの制限だそうです)
data:image/s3,"s3://crabby-images/b2593/b2593b7a5bd7ccd946d97e9a18d5b7e31717bb92" alt=""
最後に、アナログ時計の完成品を載せておきます。
これは一度もプログラムを手打ちせずに、プロンプトだけで、自由文入力で修正指示をして、完成させたものです。
data:image/s3,"s3://crabby-images/7c7d9/7c7d95fc666636bd982866809d95f8e23bc2828f" alt=""
AIが作成したアナログ時計の埋め込みコード
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title>アナログ時計</title>
<style>
.clock {
width: 98px;
height: 98px;
border: 3.5px solid #B08968;
border-radius: 50%;
position: relative;
background: #ffffff;
margin-left: 7px;
}
.hand {
position: absolute;
transform-origin: bottom center;
background: #333;
z-index: 2; /* 針を日付の前面に配置 */
}
.hour {
width: 2.8px;
height: 24.5px;
top: 24.5px;
left: 47.6px;
}
.minute {
width: 2.1px;
height: 35px;
top: 14px;
left: 48.3px;
}
.second {
width: 0.7px;
height: 39.9px;
top: 9.1px;
left: 49px;
background: #f00;
}
.center {
width: 5.6px;
height: 5.6px;
background: #333;
border-radius: 50%;
position: absolute;
top: 46.2px;
left: 46.2px;
z-index: 3; /* 中心点を最前面に配置 */
}
.number {
position: absolute;
font-size: 11px;
font-weight: normal;
font-family: Arial, sans-serif;
color: #333;
width: 14px;
height: 14px;
text-align: center;
line-height: 14px;
}
.date {
position: absolute;
font-size: 10px;
font-weight: bold;
font-family: Arial, sans-serif;
color: #ffffff;
background-color: #000000;
width: 34px;
text-align: center;
bottom: 26px;
left: 32px;
padding: 1px 0;
border-radius: 3px;
z-index: 1; /* 日付を針の背面に配置 */
}
</style>
</head>
<body>
<div class="clock">
<div class="date"></div>
<div class="hand hour"></div>
<div class="hand minute"></div>
<div class="hand second"></div>
<div class="center"></div>
</div>
<script>
function updateClock() {
const now = new Date();
const hours = now.getHours() % 12;
const minutes = now.getMinutes();
const seconds = now.getSeconds();
const milliseconds = now.getMilliseconds();
const hourDeg = (hours + minutes / 60) * 30;
const minuteDeg = (minutes + seconds / 60) * 6;
const secondDeg = (seconds + milliseconds / 1000) * 6;
document.querySelector('.hour').style.transform = `rotate(${hourDeg}deg)`;
document.querySelector('.minute').style.transform = `rotate(${minuteDeg}deg)`;
document.querySelector('.second').style.transform = `rotate(${secondDeg}deg)`;
// 日付を更新(月/日の形式)
const month = now.getMonth() + 1;
const date = now.getDate();
document.querySelector('.date').textContent = `${month} / ${date}`;
}
function addNumbers() {
const clock = document.querySelector('.clock');
const radius = 39;
const centerX = 49;
const centerY = 49;
for (let i = 1; i <= 12; i++) {
const number = document.createElement('div');
number.className = 'number';
number.textContent = i;
const angle = (i - 3) * (Math.PI / 6);
const x = centerX + radius * Math.cos(angle);
const y = centerY + radius * Math.sin(angle);
number.style.left = `${x - 7}px`;
number.style.top = `${y - 7}px`;
clock.appendChild(number);
}
}
setInterval(updateClock, 50);
addNumbers();
</script>
</body>
</html>
⑥おわりに
いかがでしたでしょうか?
Claude3.5Sonnetが、他と比較してかなり賢くなっていることがわかりました。
とくに、入力プロンプトへの理解レベルがすごく高く、指示に素直なのです。
こちらの言ったことを、きちんとやってくれますし、さらに、かゆいところに手が届くサジェスションも入れてくれるので、プロンプトでの指示が非常に楽でした。
残念ながら、Geminiのように大量の文書を取り込む力はありませんし、入力制限がかかりやすいので、使い所を問われますが、小気味の良いAIだと思いました。
data:image/s3,"s3://crabby-images/03cb5/03cb5515cc5cc5b437c793c93a060ae162327568" alt=""
※有料エリアには何も書かれていません。もし、記事が気に入ったら、購入願います。
ここから先は
¥ 100
data:image/s3,"s3://crabby-images/8a82f/8a82f1f7d54f35d25535baae7b8839241b1b0dd9" alt="PayPay"
この記事が気に入ったらチップで応援してみませんか?