功能:随机浮漂钓鱼防挂机 + 商店自动钓鱼卡
核心变更: 1. FishingController 重写 - cast(): 生成随机浮漂坐标(x/y%) + 一次性 token - reel(): 必须携带 token 才能收竿(防脚本绕过) - 检测自动钓鱼卡剩余时间并返回给前端 2. 前端钓鱼逻辑重写 - 抛竿后显示随机位置 🪝 浮漂动画(全屏飘动) - 鱼上钩时浮漂「下沉」动画,8秒内点击浮漂才能收竿 - 超时未点击:鱼跑了,token 也失效 - 持有自动钓鱼卡:自动点击,紫色提示剩余时间 3. 商店新增「🎣 自动钓鱼卡」分组 - 3档:2h(800金)/8h(2500金)/24h(6000金) - 图标徽章显示剩余有效时间(紫色) - 购买后即时激活,无需手动操作 4. 数据库 - shop_items.type 加 auto_fishing 枚举 - shop_items.duration_minutes 新字段(分钟精度) - Seeder 写入 3 张卡数据 防挂机原理:按钮 → 浮漂随机位置,脚本无法固定坐标点击
This commit is contained in:
@@ -799,6 +799,11 @@
|
||||
desc: '存入背包,求婚时消耗(被拒则遗失)',
|
||||
type: 'ring'
|
||||
},
|
||||
{
|
||||
label: '🎣 自动钓鱼卡',
|
||||
desc: '激活后自动收篼,无需手动点击浮漂',
|
||||
type: 'auto_fishing'
|
||||
},
|
||||
{
|
||||
label: '🎭 道具',
|
||||
desc: '',
|
||||
@@ -828,13 +833,30 @@
|
||||
const card = document.createElement('div');
|
||||
card.className = 'shop-card';
|
||||
|
||||
// 顶部:图标 + 名称(戒指加持有数徽章)
|
||||
const iconHtml = isRing && ownedQty > 0 ?
|
||||
`<span style="position:relative;display:inline-block;">
|
||||
// 顶部:图标 + 名称(戒指/自动钓鱼卡加徽章)
|
||||
const isAutoFishing = item.type === 'auto_fishing';
|
||||
const autoFishLeft = isAutoFishing ? (data.auto_fishing_minutes_left || 0) : 0;
|
||||
|
||||
let iconHtml;
|
||||
if (isRing && ownedQty > 0) {
|
||||
iconHtml = `<span style="position:relative;display:inline-block;">
|
||||
<span class="shop-card-icon">${item.icon}</span>
|
||||
<span style="position:absolute;top:-4px;right:-6px;background:#f43f5e;color:#fff;font-size:9px;font-weight:800;min-width:15px;height:15px;border-radius:8px;text-align:center;line-height:15px;padding:0 2px;">${ownedQty}</span>
|
||||
</span>` :
|
||||
`<span class="shop-card-icon">${item.icon}</span>`;
|
||||
</span>`;
|
||||
} else if (isAutoFishing && autoFishLeft > 0) {
|
||||
const hLeft = autoFishLeft >= 60 ? Math.floor(autoFishLeft / 60) + 'h' :
|
||||
autoFishLeft + 'm';
|
||||
iconHtml = `<span style="position:relative;display:inline-block;">
|
||||
<span class="shop-card-icon">${item.icon}</span>
|
||||
<span style="position:absolute;top:-4px;right:-6px;background:#7c3aed;color:#fff;font-size:9px;font-weight:800;min-width:18px;height:15px;border-radius:8px;text-align:center;line-height:15px;padding:0 2px;">${hLeft}</span>
|
||||
</span>`;
|
||||
} else {
|
||||
iconHtml = `<span class="shop-card-icon">${item.icon}</span>`;
|
||||
}
|
||||
|
||||
const durationLabel = isAutoFishing && item.duration_minutes > 0 ?
|
||||
`<div style="font-size:9px;margin-top:3px;color:#7c3aed;">⏱ 有效期 ${item.duration_minutes >= 60 ? Math.floor(item.duration_minutes / 60) + ' 小时' : item.duration_minutes + ' 分钟'}</div>` :
|
||||
'';
|
||||
|
||||
card.innerHTML = `
|
||||
<div class="shop-card-top">
|
||||
@@ -847,6 +869,7 @@
|
||||
${item.intimacy_bonus > 0 ? `<span style="color:#f43f5e;">💞 亲密 +${item.intimacy_bonus}</span>` : ''}
|
||||
${item.charm_bonus > 0 ? `<span style="color:#a855f7;">✨ 魅力 +${item.charm_bonus}</span>` : ''}
|
||||
</div>` : ''}
|
||||
${durationLabel}
|
||||
`;
|
||||
|
||||
// 按钮
|
||||
|
||||
Reference in New Issue
Block a user