新增可解锁Hold机制并补全特殊强化提示
This commit is contained in:
@@ -332,6 +332,7 @@ void TDrawScreen(HDC hdc, HWND hWnd)
|
||||
_T("\u2191 / W\uff1a\u65cb\u8f6c\u65b9\u5757\r\n")
|
||||
_T("\u2193 / S\uff1a\u8f6f\u964d\r\n")
|
||||
_T("Space\uff1a\u786c\u964d\r\n")
|
||||
_T("C / Shift\uff1aHold\uff08\u89e3\u9501\u540e\uff09\r\n")
|
||||
_T("P\uff1a\u6682\u505c / \u7ee7\u7eed\r\n")
|
||||
_T("R\uff1a\u91cd\u5f00\u5f53\u524d\u5bf9\u5c40\r\n")
|
||||
_T("M\uff1a\u8fd4\u56de\u4e3b\u83dc\u5355"),
|
||||
@@ -361,7 +362,7 @@ void TDrawScreen(HDC hdc, HWND hWnd)
|
||||
hdc,
|
||||
_T("\u7ecf\u5178\u6a21\u5f0f\uff1a\u4fdd\u6301\u539f\u7248\u4fc4\u7f57\u65af\u65b9\u5757\u73a9\u6cd5\uff0c\u4ee5\u6d88\u884c\u548c\u751f\u5b58\u4e3a\u4e3b\u3002\r\n\r\n")
|
||||
_T("Rogue \u6a21\u5f0f\uff1a\u6d88\u884c\u540e\u9664\u4e86\u83b7\u5f97\u5206\u6570\uff0c\u8fd8\u4f1a\u83b7\u5f97 EXP\u3002EXP \u8fbe\u5230\u9608\u503c\u540e\u89e6\u53d1\u5347\u7ea7\uff0c\u4ece\u4e09\u4e2a\u5f3a\u5316\u4e2d\u9009\u4e00\u4e2a\u3002\r\n\r\n")
|
||||
_T("\u5f53\u524d\u5df2\u63a5\u5165\uff1a\u5206\u6570\u500d\u7387\u3001EXP \u500d\u7387\u3001\u6162\u901f\u4e0b\u843d\u3002\r\n\r\n")
|
||||
_T("\u5f53\u524d\u5df2\u63a5\u5165\uff1a\u5206\u6570\u500d\u7387\u3001EXP \u500d\u7387\u3001\u6162\u901f\u4e0b\u843d\u3001Hold \u89e3\u9501\u3002\r\n\r\n")
|
||||
_T("\u63d0\u793a\uff1a\u6682\u505c\u3001\u5931\u8d25\u548c\u5347\u7ea7\u4f1a\u8fdb\u5165\u4e0d\u540c\u754c\u9762\uff0c\u8bf7\u6839\u636e\u5c4f\u5e55\u63d0\u793a\u64cd\u4f5c\u3002"),
|
||||
-1,
|
||||
&rulesBody,
|
||||
@@ -736,11 +737,87 @@ void TDrawScreen(HDC hdc, HWND hWnd)
|
||||
SetTextColor(hdc, textColor);
|
||||
}
|
||||
|
||||
int previewTitleTop = (currentMode == MODE_ROGUE) ? panelRect.top + SS(690) : panelRect.top + SS(430);
|
||||
int nextCardTop = (currentMode == MODE_ROGUE) ? panelRect.top + SS(724) : panelRect.top + SS(472);
|
||||
int holdTitleTop = (currentMode == MODE_ROGUE) ? panelRect.top + SS(690) : panelRect.top + SS(430);
|
||||
int holdCardTop = (currentMode == MODE_ROGUE) ? panelRect.top + SS(724) : panelRect.top + SS(472);
|
||||
int previewTitleTop = holdTitleTop;
|
||||
int nextCardTop = holdCardTop;
|
||||
int hintTop = (currentMode == MODE_ROGUE) ? panelRect.top + SS(818) : panelRect.top + SS(656);
|
||||
|
||||
TextOut(hdc, panelRect.left + SS(24), previewTitleTop, _T("\u4e0b\u4e00\u4e2a\u65b9\u5757"), lstrlen(_T("\u4e0b\u4e00\u4e2a\u65b9\u5757")));
|
||||
if (currentMode == MODE_ROGUE)
|
||||
{
|
||||
TextOut(hdc, panelRect.left + SS(24), holdTitleTop, _T("Hold \u69fd"), lstrlen(_T("Hold \u69fd")));
|
||||
|
||||
RECT holdCard =
|
||||
{
|
||||
panelRect.left + SS(24),
|
||||
holdCardTop,
|
||||
panelRect.left + SS(24) + grid * 2 + SS(40),
|
||||
holdCardTop + grid * 2 + SS(40)
|
||||
};
|
||||
DrawPanelCard(holdCard, RGB(255, 238, 244), RGB(233, 191, 208), 22);
|
||||
|
||||
if (rogueStats.holdUnlocked == 0)
|
||||
{
|
||||
SelectObject(hdc, smallFont);
|
||||
SetTextColor(hdc, RGB(128, 104, 118));
|
||||
RECT holdLockedRect =
|
||||
{
|
||||
holdCard.left + SS(10),
|
||||
holdCard.top + SS(18),
|
||||
holdCard.right - SS(10),
|
||||
holdCard.bottom - SS(10)
|
||||
};
|
||||
DrawText(hdc, _T("\u672a\u89e3\u9501\r\n\u83b7\u53d6 Hold \u5f3a\u5316\u540e\u53ef\u7528"), -1, &holdLockedRect, DT_CENTER | DT_VCENTER | DT_WORDBREAK);
|
||||
}
|
||||
else if (holdType >= 0)
|
||||
{
|
||||
for (int i = 0; i < 4; i++)
|
||||
{
|
||||
for (int j = 0; j < 4; j++)
|
||||
{
|
||||
if (bricks[holdType][0][i][j] != 0)
|
||||
{
|
||||
RECT brickRect =
|
||||
{
|
||||
holdCard.left + SS(14) + j * (grid / 2),
|
||||
holdCard.top + SS(14) + i * (grid / 2),
|
||||
holdCard.left + SS(14) + (j + 1) * (grid / 2) - SS(1),
|
||||
holdCard.top + SS(14) + (i + 1) * (grid / 2) - SS(1)
|
||||
};
|
||||
|
||||
HBRUSH brickBrush = CreateSolidBrush(BrickColor[holdType]);
|
||||
HPEN brickPen = CreatePen(PS_SOLID, 1, RGB(255, 248, 250));
|
||||
oldPen = (HPEN)SelectObject(hdc, brickPen);
|
||||
oldBrush = (HBRUSH)SelectObject(hdc, brickBrush);
|
||||
RoundRect(hdc, brickRect.left, brickRect.top, brickRect.right, brickRect.bottom, SS(8), SS(8));
|
||||
SelectObject(hdc, oldBrush);
|
||||
SelectObject(hdc, oldPen);
|
||||
DeleteObject(brickBrush);
|
||||
DeleteObject(brickPen);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
SelectObject(hdc, smallFont);
|
||||
SetTextColor(hdc, RGB(128, 104, 118));
|
||||
RECT emptyHoldRect =
|
||||
{
|
||||
holdCard.left + SS(10),
|
||||
holdCard.top + SS(18),
|
||||
holdCard.right - SS(10),
|
||||
holdCard.bottom - SS(10)
|
||||
};
|
||||
DrawText(hdc, _T("\u6682\u65e0\u6682\u5b58\r\nC / Shift \u53ef\u5b58\u5165\u5f53\u524d\u65b9\u5757"), -1, &emptyHoldRect, DT_CENTER | DT_VCENTER | DT_WORDBREAK);
|
||||
}
|
||||
|
||||
previewTitleTop = holdTitleTop;
|
||||
nextCardTop = holdCardTop;
|
||||
}
|
||||
|
||||
int previewLabelLeft = panelRect.left + SS((currentMode == MODE_ROGUE) ? 132 : 24);
|
||||
TextOut(hdc, previewLabelLeft, previewTitleTop, _T("\u4e0b\u4e00\u4e2a\u65b9\u5757"), lstrlen(_T("\u4e0b\u4e00\u4e2a\u65b9\u5757")));
|
||||
|
||||
int previewCount = 1;
|
||||
if (currentMode == MODE_ROGUE)
|
||||
@@ -760,9 +837,9 @@ void TDrawScreen(HDC hdc, HWND hWnd)
|
||||
{
|
||||
RECT nextCard =
|
||||
{
|
||||
panelRect.left + SS(24) + previewIndex * SS(94),
|
||||
previewLabelLeft + previewIndex * SS(94),
|
||||
nextCardTop,
|
||||
panelRect.left + SS(24) + previewIndex * SS(94) + grid * 2 + SS(40),
|
||||
previewLabelLeft + previewIndex * SS(94) + grid * 2 + SS(40),
|
||||
nextCardTop + grid * 2 + SS(40)
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user