Skip to content

Commit

Permalink
Merge pull request #1319 from beru/UpdateToolbar_2nd
Browse files Browse the repository at this point in the history
ツールバーの状態更新を必要な場合にのみ行うように変更
  • Loading branch information
beru committed Jun 6, 2020
2 parents 6e75abe + 5ad814f commit 96cf722
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 14 deletions.
2 changes: 2 additions & 0 deletions sakura_core/apiwrap/CommonControl.h
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,8 @@ namespace ApiWrap
inline int Toolbar_SetButtonInfo(HWND hwndCtl, int index, TBBUTTONINFO* info) { return (int)(DWORD)::SendMessage(hwndCtl, TB_SETBUTTONINFO, (WPARAM)index, (LPARAM)info); }
inline BOOL Toolbar_SetButtonSize(HWND hwndCtl, int width, int height) { return (BOOL)(DWORD)::SendMessage(hwndCtl, TB_SETBUTTONSIZE, 0L, MAKELONG(width, height)); }
inline DWORD Toolbar_SetExtendedStyle(HWND hwndCtl, DWORD styles) { return (DWORD)::SendMessage(hwndCtl, TB_SETEXTENDEDSTYLE, 0L, (LPARAM)styles); }
inline int Toolbar_GetState(HWND hwndCtl, int index) { return (int)::SendMessage(hwndCtl, TB_GETSTATE, (WPARAM)index, 0L); }
inline BOOL Toolbar_SetState(HWND hwndCtl, int index, WORD state) { return (BOOL)::SendMessage(hwndCtl, TB_SETSTATE, (WPARAM)index, state); }

// -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- //
// Tooltip コントロール //
Expand Down
33 changes: 19 additions & 14 deletions sakura_core/window/CMainToolBar.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -535,20 +535,25 @@ void CMainToolBar::UpdateToolbar( void )
TBBUTTON tbb = m_pOwner->GetMenuDrawer().getButton(
GetDllShareData().m_Common.m_sToolBar.m_nToolBarButtonIdxArr[i]
);

// 機能が利用可能か調べる
Toolbar_EnableButton(
m_hwndToolBar,
tbb.idCommand,
IsFuncEnable( m_pOwner->GetDocument(), &GetDllShareData(), (EFunctionCode)tbb.idCommand )
);

// 機能がチェック状態か調べる
Toolbar_CheckButton(
m_hwndToolBar,
tbb.idCommand,
IsFuncChecked( m_pOwner->GetDocument(), &GetDllShareData(), (EFunctionCode)tbb.idCommand )
);
int state = Toolbar_GetState( m_hwndToolBar, tbb.idCommand );
if( state != -1 )
{
WORD stateToSet = state & ~(TBSTATE_ENABLED | TBSTATE_CHECKED);
// 機能が利用可能か調べる
if( IsFuncEnable( m_pOwner->GetDocument(), &GetDllShareData(), (EFunctionCode)tbb.idCommand ) )
{
stateToSet |= TBSTATE_ENABLED;
}
// 機能がチェック状態か調べる
if( IsFuncChecked( m_pOwner->GetDocument(), &GetDllShareData(), (EFunctionCode)tbb.idCommand ) )
{
stateToSet |= TBSTATE_CHECKED;
}
if( state != stateToSet )
{
Toolbar_SetState( m_hwndToolBar, tbb.idCommand, stateToSet );
}
}
}
}
}
Expand Down

0 comments on commit 96cf722

Please sign in to comment.