# 枫火歌者种火战斗机制修复

## 修改时间
2025-01-03 14:52:00 (NOUVEAU DAY -95)

## 问题描述
根据用户测试反馈，枫火歌者的机制存在以下问题：
1. 玩家在探索·移动时可能遇到自己配下的种火并与其发起战斗甚至将其杀死
2. 种火的索敌逻辑会对同玩家的其他种火NPC造成伤害

在虚构层上，这些行为是不可接受的，需要进行修复。

## 修改内容

### 1. 修改遇敌逻辑 (include/game/search.func.php)

在 `discover` 函数的遇敌判断逻辑中添加了对枫火歌者玩家遇到自己配下种火的特殊处理：

**修改位置**: 第741-759行
**修改逻辑**:
- 在遇敌循环中，当玩家为枫火歌者(club == 22)且遇到种火NPC(type == 92)时
- 检查该种火的owner字段是否为当前玩家的pid
- 如果是自己配下的种火，则跳过战斗并显示友好文案
- 继续寻找其他可能的敌人

**显示文案**:
- "你遇到了自己配下的种火「种火名称」。"
- "「种火名称」友好地看着你，你们没有发生冲突。"

### 2. 修改种火索敌逻辑 (include/game/club22.func.php)

在 `FireseedDrainNPC` 函数中添加了对同玩家其他种火NPC的保护：

**修改位置**: 第331-350行
**修改逻辑**:
- 在索敌循环中，当目标NPC为种火(type == 92)时
- 检查该种火的owner字段是否为当前玩家的pid
- 如果是同玩家的种火，则跳过攻击
- 继续寻找其他可攻击的NPC目标

## 技术细节

### 数据结构处理
- 使用 `get_clbpara()` 函数确保NPC的clbpara字段为数组格式
- 通过检查 `$npc['clbpara']['owner']` 字段判断种火归属
- 使用 `$pid` 变量标识当前玩家

### 兼容性考虑
- 修改不影响其他社团的正常遇敌逻辑
- 修改不影响种火对其他类型NPC的索敌功能
- 保持了原有的防御力和技能检查逻辑

## 预期效果

1. **遇敌逻辑修复**: 枫火歌者玩家不会再与自己配下的种火发生战斗
2. **索敌逻辑修复**: 种火不会攻击同玩家的其他种火NPC
3. **虚构层合理性**: 符合枫火歌者与种火之间的主从关系设定

## 测试建议

1. 测试枫火歌者玩家在有自己种火的地图上移动/探索
2. 测试种火索敌功能是否正常工作但不攻击同玩家种火
3. 测试其他社团玩家的正常遇敌逻辑是否受影响
4. 测试种火对其他类型NPC的索敌功能是否正常

## 相关文件

- `include/game/search.func.php` - 遇敌逻辑修改
- `include/game/club22.func.php` - 种火索敌逻辑修改
