X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=KancolleSniffer%2FModel%2FQuestCountList.cs;h=12ea13083f71d06f24b88d7648f7555ffa371f94;hb=0f377e30b207441f57037b55a1412947afa6b1e7;hp=c0699fa827d9afef2ac31c490acad177bc6dfbd5;hpb=a9f098909d59d4a48155da92b8bb3a78ba1ae2cf;p=kancollesniffer%2FKancolleSniffer.git
diff --git a/KancolleSniffer/Model/QuestCountList.cs b/KancolleSniffer/Model/QuestCountList.cs
index c0699fa..12ea130 100644
--- a/KancolleSniffer/Model/QuestCountList.cs
+++ b/KancolleSniffer/Model/QuestCountList.cs
@@ -23,14 +23,19 @@ namespace KancolleSniffer.Model
private const QuestInterval Weekly = QuestInterval.Weekly;
private const QuestInterval Monthly = QuestInterval.Monthly;
private const QuestInterval Quarterly = QuestInterval.Quarterly;
- private const QuestInterval Yearly = QuestInterval.Yearly;
+ private const QuestInterval Yearly2 = QuestInterval.Yearly2;
+ private const QuestInterval Yearly3 = QuestInterval.Yearly3;
+ private const QuestInterval Yearly5 = QuestInterval.Yearly5;
+ private const QuestInterval Yearly8 = QuestInterval.Yearly8;
+ private const QuestInterval Yearly9 = QuestInterval.Yearly9;
+ private const QuestInterval Yearly10 = QuestInterval.Yearly10;
///
/// ãã®ãã¼ãã«ã¯ä¸åå¼é»å観測åãåèã«ä½æããã
/// https://github.com/andanteyk/ElectronicObserver/blob/develop/ElectronicObserver/Data/Quest/QuestProgressManager.cs
///
// @formatter:off
- private static readonly Dictionary QuestSpecs = new Dictionary
+ private readonly Dictionary _questSpecs = new Dictionary
{
{201, new QuestSortie {Interval = Daily, Max = 1, Rank = "B", Material = new[] {0, 0, 1, 0}}}, // 201: æµè¦éãææ»
ããï¼
{216, new QuestSortie {Interval = Daily, Max = 1, Rank = "B", Material = new[] {0, 1, 1, 0}}}, // 216: æµè¦é主åãææ»
ããï¼
@@ -72,8 +77,11 @@ namespace KancolleSniffer.Model
{888, new QuestSortie {Interval = Quarterly, MaxArray = new[] {1, 1, 1}, Rank = "S", Maps = new[] {51, 53, 54}, Material = new[] {0, 0, 0, 0}}}, // 888: æ°ç·¨æãä¸å·è¦éããéåºæµ·å³¡ã«çªå
¥ããï¼
{893, new QuestSortie {Interval = Quarterly, MaxArray = new[] {3, 3, 3, 3}, Rank = "S", Maps = new[] {15, 71, 721, 722}, Material = new[] {0, 0, 0, 0}}}, // 893: æ³å°å¨è¾ºæµ·åã®å®å
¨ç¢ºä¿ãå¾¹åºããï¼
{894, new QuestSortie {Interval = Quarterly, MaxArray = new[] {1, 1, 1, 1, 1}, Rank = "S", Maps = new[] {13, 14, 21, 22, 23}, Material = new[] {0, 0, 0, 0}}}, // 894: 空æ¯æ¦åã®æå
¥ã«ããå
µç«ç·æ¦éå¨æ
- {904, new QuestSortie {Interval = Yearly, MaxArray = new[] {1, 1, 1, 1}, Rank = "S", Maps = new[] {25, 34, 45, 53}, Material = new[] {0, 8, 10, 4}}}, // 904: ç²¾éãåä¹é§ããèºãåºãï¼
- {905, new QuestSortie {Interval = Yearly, MaxArray = new[] {1, 1, 1, 1, 1}, Rank = "A", Maps = new[] {11, 12, 13, 15, 16}, Material = new[] {0, 6, 8, 0}}}, // 905: ãæµ·é²è¦ããæµ·ãè·ãï¼
+ {903, new QuestSortie {Interval = Quarterly, MaxArray = new[] {1, 1, 1, 1}, Rank = "S", Maps = new[] {51, 54, 64, 65}, Material = new[] {0, 10, 0, 0}}}, // 903: æ¡å¼µãå
æ°´æ¦ããæåç·ã¸ï¼
+ {904, new QuestSortie {Interval = Yearly2, MaxArray = new[] {1, 1, 1, 1}, Rank = "S", Maps = new[] {25, 34, 45, 53}, Material = new[] {0, 8, 10, 4}}}, // 904: ç²¾éãåä¹é§ããèºãåºãï¼
+ {905, new QuestSortie {Interval = Yearly2, MaxArray = new[] {1, 1, 1, 1, 1}, Rank = "A", Maps = new[] {11, 12, 13, 15, 16}, Material = new[] {0, 6, 8, 0}}}, // 905: ãæµ·é²è¦ããæµ·ãè·ãï¼
+ {912, new QuestSortie {Interval = Yearly3, MaxArray = new[] {1, 1, 1, 1, 1}, Rank = "A", Maps = new[] {13, 21, 22, 23, 16}, Material = new[] {0, 5, 6, 0}}}, // 912: å·¥ä½è¦ãæç³ãè·è¡ä»»å
+ {914, new QuestSortie {Interval = Yearly3, MaxArray = new[] {1, 1, 1, 1}, Rank = "A", Maps = new[] {41, 42, 43, 44}, Material = new[] {0, 5, 0, 4}}}, // 914: éå·¡æ¦éã西ã¸ï¼
{303, new QuestPractice {Interval = Daily, Max = 3, Rank = "E", Material = new[] {1, 0, 0, 0}}}, // 303: ãæ¼ç¿ãã§ç·´åº¦åä¸ï¼
{304, new QuestPractice {Interval = Daily, Max = 5, Rank = "B", Material = new[] {0, 0, 1, 0}}}, // 304: ãæ¼ç¿ãã§ä»æç£ãå§åããï¼
@@ -82,8 +90,11 @@ namespace KancolleSniffer.Model
{315, new QuestPractice {Interval = Daily, Max = 8, Rank = "B", Material = new[] {0, 0, 0, 0}}}, // 315: æ¥å£å¤§æ¼ç¿
{318, new QuestPractice {Interval = Daily, Max = 3, Rank = "B", Material = new[] {0, 2, 2, 0}, AdjustCount = false}}, // 318: 給糧è¦ãä¼è¯æ¹ãã®æ¯æ´
{330, new QuestPractice {Interval = Daily, Max = 4, Rank = "A", Material = new[] {0, 0, 3, 0}}}, // 330: 空æ¯æ©åé¨éãæ¼ç¿å§ãï¼
- {337, new QuestPractice {Interval = Daily, Max = 3, Rank = "S", Material = new[] {0, 0, 0, 3}}}, // 337: ãåå
«é§ãæ¼ç¿ï¼
- {339, new QuestPractice {Interval = Daily, Max = 3, Rank = "S", Material = new[] {0, 0, 8, 3}}}, // 339: ãåä¹é§ãæ¼ç¿ï¼
+ {337, new QuestPractice {Interval = Daily, Max = 3, Rank = "S", Material = new[] {0, 0, 0, 3}, Shift = 2}}, // 337: ãåå
«é§ãæ¼ç¿ï¼
+ {339, new QuestPractice {Interval = Daily, Max = 3, Rank = "S", Material = new[] {0, 0, 8, 3}, Shift = 2}}, // 339: ãåä¹é§ãæ¼ç¿ï¼
+ {342, new QuestPractice {Interval = Quarterly, Max = 4, Rank = "A", Material = new[] {0, 4, 4, 0}, Shift = 1}}, // 342: å°è¦è群æ¼ç¿å¼·åä»»å
+ {345, new QuestPractice {Interval = Yearly10, Max = 4, Rank = "A", Material = new[] {0, 5, 4, 0}, Shift = 1}}, // 345: æ¼ç¿ãã£ã¼ã¿ã¤ã ï¼
+ {346, new QuestPractice {Interval = Yearly10, Max = 4, Rank = "S", Material = new[] {0, 4, 6, 0}, Shift = 1}}, // 346: æç²¾éï¼ä¸»åãªã主åãæ¼ç¿éå§ï¼
{402, new QuestMission {Interval = Daily, Max = 3, Material = new[] {0, 0, 1, 0}}}, // 402: ãé å¾ãã3åæåããããï¼
{403, new QuestMission {Interval = Daily, Max = 10, Material = new[] {0, 0, 0, 0}}}, // 403: ãé å¾ãã10åæåããããï¼
@@ -93,6 +104,12 @@ namespace KancolleSniffer.Model
{424, new QuestMission {Interval = Monthly, Max = 4, Shift = 1, Ids = new[] {5}, Material = new[] {0, 0, 0, 0}}}, // 424: 輸éè¹å£è·è¡ãå¼·åããï¼
{426, new QuestMission {Interval = Quarterly, MaxArray = new[] {1, 1, 1, 1}, Ids = new[] {3, 4, 5, 10}, Material = new[] {0, 0, 4, 0}}}, // 426: æµ·ä¸éåèªè·¯ã®è¦æãå³ã¨ããï¼
{428, new QuestMission {Interval = Quarterly, MaxArray = new[] {2, 2, 2}, Ids = new[] {4, 101, 102}, Material = new[] {0, 0, 0, 3}}}, // 428: è¿æµ·ã«ä¾µå
¥ããæµæ½ãå¶å§ããï¼
+ {434, new QuestMission {Interval = Yearly2, MaxArray = new[] {1, 1, 1, 1, 1}, Ids = new[] {3, 5, 100, 101, 9}, Material = new[] {0, 5, 0, 3}}}, // 434: ç¹è¨è·è¡è¹å£å¸ä»¤é¨ãæ´»åéå§ï¼
+ {436, new QuestMission {Interval = Yearly3, MaxArray = new[] {1, 1, 1, 1, 1}, Ids = new[] {1, 2, 3, 4, 10}, Material = new[] {0, 4, 0, 0}}}, // 436: ç·´ç¿èªæµ·åã³è¦åä»»åãå®æ½ããï¼
+ {437, new QuestMission {Interval = Yearly5, MaxArray = new[] {1, 1, 1, 1}, Ids = new[] {4, 104, 105, 110}, Material = new[] {0, 0, 7, 3}, Shift = 1}}, // 437: å°ç¬ åæ²å¨æç·ã®å¼·åãå®æ½ããï¼
+ {438, new QuestMission {Interval = Yearly8, MaxArray = new[] {1, 1, 1, 1}, Ids = new[] {4, 100, 9, 114}, Material = new[] {0, 0, 5, 4}, Shift = 1}}, // 438: å西諸島æ¹é¢ã®æµ·ä¸è·è¡ãå¼·åããï¼
+ {439, new QuestMission {Interval = Yearly9, MaxArray = new[] {1, 1, 1, 1}, Ids = new[] {5, 100, 11, 110}, Material = new[] {0, 0, 5, 4}, Shift = 1}}, // 439: å
µç«å¼·åé å¾ä»»åãåºæ¬ä½æ¦ã
+ {440, new QuestMission {Interval = Yearly9, MaxArray = new[] {1, 1, 1, 1, 1}, Ids = new[] {5, 41, 46, 40, 142}, Material = new[] {0, 0, 0, 4}}}, // 440: å
µç«å¼·åé å¾ä»»åãæ¡å¼µä½æ¦ã
{503, new QuestSpec {Interval = Daily, Max = 5, Material = new[] {0, 2, 0, 0}}}, // 503: è¦é大æ´åï¼
{504, new QuestSpec {Interval = Daily, Max = 15, Material = new[] {1, 0, 1, 0}}}, // 504: è¦éé
ä¿ç¥ãï¼
@@ -108,7 +125,7 @@ namespace KancolleSniffer.Model
{638, new QuestDestroyItem {Interval = Weekly, Max = 6, Types = new[] {21}, Material = new[] {0, 0, 2, 1}}}, // 638: 対空æ©ééç£
{643, new QuestDestroyItem {Interval = Quarterly, Max = 2, Ids = new[] {20}, Material = new[] {0, 0, 2, 0}, AdjustCount = false}}, // 643: 主åãé¸æ»ãã®èª¿é
{645, new QuestDestroyItem {Interval = Monthly, Max = 1, Ids = new[] {35}, Material = new[] {0, 0, 0, 0}, AdjustCount = false}}, // 645: ãæ´ä¸è£çµ¦ãç©è³ã®èª¿é
- {653, new QuestDestroyItem {Interval = Quarterly, Max = 6, Ids = new[] {4}, Material = new[] {0, 0, 0, 0}}}, // 653: å·¥å» ç¨¼åï¼æ¬¡æä½æ¦æºåï¼
+ {653, new QuestDestroyItem {Interval = Quarterly, Max = 6, Ids = new[] {4}, Material = new[] {0, 0, 0, 0}, AdjustCount = false}}, // 653: å·¥å» ç¨¼åï¼æ¬¡æä½æ¦æºåï¼
{663, new QuestDestroyItem {Interval = Quarterly, Max = 10, Types = new[] {3}, Material = new[] {0, 0, 3, 0}}}, // 663: æ°åè¤è£
ã®ç¶ç¶ç 究
{673, new QuestDestroyItem {Interval = Daily, Max = 4, Types = new[] {1}, Shift = 1, Material = new[] {0, 0, 1, 0}}}, // 673: è£
åéçºåã®æ´å
{674, new QuestDestroyItem {Interval = Daily, Max = 3, Types = new[] {21}, Shift = 2, Material = new[] {0, 1, 1, 0}}}, // 674: å·¥å» ç°å¢ã®æ´å
@@ -127,11 +144,23 @@ namespace KancolleSniffer.Model
private readonly Dictionary _countDict = new Dictionary();
+ public void SetMissionNames(dynamic json)
+ {
+ var dict = new Dictionary();
+ foreach (var entry in json)
+ dict[(int)entry.api_id] = entry.api_name;
+ foreach (var spec in _questSpecs)
+ {
+ if (spec.Value is QuestMission mission && mission.Ids != null)
+ mission.Names = mission.Ids.Select(id => dict.TryGetValue(id, out var name) ? name : "").ToArray();
+ }
+ }
+
public QuestCount GetCount(int id)
{
if (_countDict.TryGetValue(id, out var value))
return value;
- if (QuestSpecs.TryGetValue(id, out var spec))
+ if (_questSpecs.TryGetValue(id, out var spec))
{
var nowArray = spec.MaxArray?.Select(x => 0).ToArray();
return _countDict[id] = new QuestCount
@@ -167,7 +196,7 @@ namespace KancolleSniffer.Model
return;
foreach (var count in questCountList)
{
- count.Spec = QuestSpecs[count.Id];
+ count.Spec = _questSpecs[count.Id];
_countDict[count.Id] = count;
}
}