diff options
author | Andrei Karas <akaras@inbox.ru> | 2012-09-16 18:38:56 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2012-09-16 18:38:56 +0300 |
commit | f8fc3380197c078a6dcff02351d835c3022411e1 (patch) | |
tree | 0e6df38991b28539ebfadca4b4dcf6e521664ee6 | |
parent | c530b85859d0de18891781877d22b438b7693087 (diff) | |
download | manaplus-f8fc3380197c078a6dcff02351d835c3022411e1.tar.gz manaplus-f8fc3380197c078a6dcff02351d835c3022411e1.tar.bz2 manaplus-f8fc3380197c078a6dcff02351d835c3022411e1.tar.xz manaplus-f8fc3380197c078a6dcff02351d835c3022411e1.zip |
Improve inventory resize speed.
-rw-r--r-- | src/gui/widgets/itemcontainer.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/gui/widgets/itemcontainer.cpp b/src/gui/widgets/itemcontainer.cpp index 19f35ff02..aa254c30b 100644 --- a/src/gui/widgets/itemcontainer.cpp +++ b/src/gui/widgets/itemcontainer.cpp @@ -541,24 +541,27 @@ void ItemContainer::updateMatrix() break; } + int jMult = j * mGridColumns; + const int maxSize = mGridRows * mGridColumns; for (std::vector<ItemIdPair*>::const_iterator iter = sortedItems.begin(), iter_end = sortedItems.end(); iter != iter_end; ++ iter) { - if (j >= mGridRows) + if (jMult >= maxSize) break; - mShowMatrix[j * mGridColumns + i] = (*iter)->mId; + mShowMatrix[jMult + i] = (*iter)->mId; i ++; if (i >= mGridColumns) { i = 0; j ++; + jMult += mGridColumns; } } for (int idx = j * mGridColumns + i; - idx < mGridRows * mGridColumns; idx ++) + idx < maxSize; idx ++) { mShowMatrix[idx] = -1; } |