This commit is contained in:
2026-01-20 19:41:40 +08:00
parent af565b166f
commit d60a9b0d8f
2 changed files with 101 additions and 84 deletions
+41 -30
View File
@@ -2,7 +2,6 @@
class BcmTool
{
private attributes = new Map<string, number>([
['年龄', -100],
['速度', 1],
['力量', 2],
['内攻', 3],
@@ -78,7 +77,7 @@ class BcmTool
g_game.tools.CopyStrToClipboard(form.ToString());
}
public BulkSearchMarket(searchStr: string, maxIterate = 100)
public async BulkSearchMarket(searchStr: string, maxIterate = 100)
{
searchStr = searchStr.replace(/ /g, '');
const strs = searchStr.split('&&');
@@ -134,37 +133,43 @@ class BcmTool
requireSearch.push(requires[0]);
}
this.mgrMarket.SendSynOpenMarketInfoByFilter(async () =>
var results: CPlayerData[] = [];
const ids = Object.keys(this.mgrMarket._map_player_infos);
for (const id of ids)
{
var results: CPlayerData[] = [];
const ids = Object.keys(this.mgrMarket._map_player_infos);
for (const id of ids)
if (maxIterate < 0)
{
break;
}
const info = this.mgrMarket._map_player_infos[id];
if (!this.CheckInfo(info.playerId))
{
if (maxIterate < 0)
{
break;
}
const info = this.mgrMarket._map_player_infos[id];
await this.RefreshPlayerInTransaction(info.teamId, info.playerId);
if (conditions.every((e, i) => e(info.playerId, requireAttributes[i], requireValues[i])))
{
results.push(info);
}
await this.Wait(100);
maxIterate -= 1;
}
const displays = new Set<number>(requireAttributes);
for (const result of results)
if (conditions.every((e, i) => e(info.playerId, requireAttributes[i], requireValues[i])))
{
const displayStr = [...displays].map(e =>
{
const idx = requireAttributes.indexOf(e);
const search = requireSearch[idx];
const value = result.GetSingleAttribute(e, true);
return `${search}:${value}`;
});
console.log(result.playerName, ...displayStr);
results.push(info);
}
});
}
const displays = new Set<number>(requireAttributes);
for (const result of results)
{
const displayStr = [...displays].map(e =>
{
const idx = requireAttributes.indexOf(e);
const search = requireSearch[idx];
const value = this.QueryInfo(result.playerId, requireAttributes[idx]);
return `${search}:${value}`;
});
// TODO TeamName
console.log(`${result.playerName}(${result.playerAge})`, ...displayStr);
}
}
public QuickOpenPlayer(name:string) {
}
private RefreshPlayerInTransaction(teamId: string, playerId: string)
@@ -198,10 +203,6 @@ class BcmTool
public QueryInfo(playerId: string, attri: number)
{
const data = this.mgrTeamInfo.GetPlayerData(playerId);
if (attri == -100)
{
return data.playerAge;
}
return data.GetSingleAttribute(attri);
}
@@ -227,6 +228,16 @@ class BcmTool
});
}
public Wait(time: number)
{
return new Promise<void>(resolve =>
{
setTimeout(() =>
{
resolve();
}, time)
});
}
}
class Logger