मैं कुछ ऐसा कर रहा हूं जो मैक ओएस एक्स एक्सपोज़ में विंडोज़ के साथ करता है। यह वस्तुओं के पहलू अनुपात और उपलब्ध क्षेत्र के पहलू अनुपात को अपनाना है।एक्सपोज़ लेआउट एल्गोरिदम
असल में, उपलब्ध क्षेत्र पंक्तियों और स्तंभों में बांटा गया है। प्रत्येक सेल में एक आइटम लगाया जाता है (एक पंक्ति और स्तंभ का चौराहे)। कोशिकाओं के पहलू अनुपात के बावजूद वस्तुओं को उनके पहलू अनुपात (यहां width/height
) बनाए रखना चाहिए। कोशिकाओं की संख्या वस्तुओं की संख्या से अधिक या बराबर होनी चाहिए। ऐसे मामले में जहां कोशिकाओं की संख्या वस्तुओं की संख्या से अधिक है, अंतिम पंक्ति का पूरी तरह से उपयोग नहीं किया जाएगा। लक्ष्य जितना संभव हो सके आइटमों द्वारा उपयोग किए जाने वाले उपलब्ध क्षेत्र का अधिक होना है। मुझे यकीन है कि प्रत्येक सेल के पहलू अनुपात के करीब आइटम के पहलू अनुपात के लिए बेहतर है।
निम्नलिखित अच्छी तरह से काम करता है जब उपलब्ध क्षेत्र के पक्ष अनुपात आइटम 'पहलू अनुपात के बराबर है:
rows := round(sqrt(count));
columns := ceiling(sqrt(count));
कहाँ: count
आइटम्स की संख्या है, round(x)
राउंड x
निकटतम अभिन्न मूल्य तक, शून्य से दूर आधे रास्ते के मामलों को गोल करना; और ceiling(x)
सबसे छोटा अभिन्न मान x
से कम नहीं देता है।
मैं Compiz रही है कि निम्नलिखित समान एल्गोरिथ्म का उपयोग करता है, लेकिन यह ध्यान में नहीं ले करता है वस्तुओं और उपलब्ध क्षेत्र के पहलू अनुपात:
rows := floor(sqrt(count + 1));
columns := ceiling(count/rows);
कहाँ: floor(x)
सबसे बड़ा अभिन्न मूल्य नहीं x
से अधिक रिटर्न ।
मैंने निम्नलिखित ओ (एन) एल्गोरिदम को एक साथ रखा है जो पंक्तियों और स्तंभों के प्रत्येक संयोजन का परीक्षण करता है और सबसे अच्छा फिट ढूंढता है, लेकिन निश्चित रूप से ओ (1) एल्गोरिदम है क्योंकि यह पहले के समान परिणाम उत्पन्न करता है (ओ (1)) एल्गोरिथ्म जब वस्तुओं और उपलब्ध क्षेत्र के पहलू अनुपात एक ही कर रहे हैं:
fit (itemCount, itemRatio, availableRatio)
{
bestRows := infinity;
bestColumns := infinity;
bestDiff := infinity;
for (rows := 1; rows <= count; rows += 1)
{
columns := ceiling(count/rows);
cellWidth := availableRatio/columns;
cellHeight := 1.0/rows;
cellRatio := cellWidth/cellHeight;
diff := abs(cellRatio - itemRatio);
if (diff < bestDiff)
{
bestRows := rows;
bestColumns := columns;
bestDiff := diff;
if (diff = 0)
break;
}
}
return (bestRows, bestColumns);
}
कहाँ: abs(x)
x
के निरपेक्ष मान देता है।
ध्यान दें: आप यह सब
तो पर अनुकूल नहीं है देख सकते हैं, क्या संभव के रूप में आइटम द्वारा उपयोग सबसे उपलब्ध क्षेत्र के लिए सबसे अच्छा तरीका क्या है? (दूसरे शब्दों में, कैसे मैं सबसे अच्छा फिट लगता है?)
कोई भी जानकारी बिल्कुल अच्छी होगी .. मुझे पता नहीं चल सकता कि शोध करने के लिए, मुझे कुछ भी नहीं मिल रहा है। समस्या के लिए बस एक आम नाम काम करेगा। – vedosity
apriori ज्ञान के बिना आपको कम से कम सभी के आयामों को देखना होगा, ताकि पहले से ही ओ (एन) हो। मुझे ओ (1) बनाने के लिए कोई उचित तरीका नहीं दिख रहा है जब तक कि आपके पास अतिरिक्त जानकारी न हो। – lijie
आइटमों में एक ही पहलू अनुपात होता है, और जब तक उनका पहलू अनुपात समान होता है तब तक आकार बदल सकता है। आप इसे देख सकते हैं क्योंकि उनकी चौड़ाई पहलू अनुपात होगी और उनकी ऊंचाई 1 होगी, इसलिए आयाम ज्ञात मान हैं। – vedosity