animation - Animate android Gridview Items -


छवि दर्ज करें यहाँ विवरण

 यहां छवि विवरण दर्ज करें

 यहां छवि विवरण दर्ज करें

यहां छवि विवरण दर्ज करें

मैं सजीव करना चाहता हूं एक ग्रिडव्यू के आइटम, इस तरह से कि प्रत्येक आइटम को केंद्र के केंद्र में केंद्रित किया जाता है और एक आइटम दिखाई देता है, और फिर ग्रिड आइटम उसकी मूल स्थिति में वापस आ जाते हैं मैंने स्पष्टता के लिए चित्र जोड़ दिए हैं I एनीमेशन का प्रवाह अंजीर 1- अंजीर 2- अंजीर 3 - अंजीर 4 - अंजीर 1. यह कैसे किया जा सकता है?

मैंने इस तरह से इस समस्या का समाधान किया:

ए ग्रिडव्यू के कुल चौड़ाई (डब्लू) और ऊंचाई (एच) खोजें।

  डब्लू = (चौड़ाई ओफ़ईआईटीआईएम * कुल आईटैम) + (स्पेसिंग बैटिविंगइटीम्स * (कुल आईटीएम -1)) एच = (ऊंचाईओफ़ीआईटीम * कुल आईटम) + (spacingBetweenItems * (totalItem-1))   

बी। ग्रिडव्यू के केंद्र (सीएक्स, सीआई) का पता लगाएं; सीएक्स = चौड़ाई / 2, साइ = ऊंचाई / 2 एक्स समीकरण (सीएक्स) प्रत्येक आइटम के लिए एक पंक्ति में बदल जाएगा Y समीकरण (Cy) प्रत्येक आइटम के लिए एक स्तंभ में बदल जाएगा।

सी।

  1. स्थिति (0,0) पर ग्रिड आईटीएम के लिए मैट्रिक्स।

    अनुवाद के लिए प्रतिशत का पता लगाएं

    x% = (सीएक्स / डब्ल्यू) * 100, y% = (साइ / डब्ल्यू) * 100

    मैट्रिक्स की स्थिति (0,1) पर ग्रिड आईटीएम के लिए, एक्सडेलटा = 0 से एक्सडेलटा = x% p से वाई डेलटा = 0 से वाई डेलटा = या% पी

  2. ग्रिडव्यू के केंद्र के एक्स समन्वयन इस मद के करीब है, इसलिए हमें घटाया जाना है (चौड़ाई ओफ़आईआईटीआईटम + स्पेसिंगबेटिन इटम्स)।

    अब सीएक्स = सीएक्स - (चौड़ाईओफ़ईईईईटीम + स्पेसिंगबीटीइनइम्स) < पी> इस मामले में केवल एक्स समन्वय बदल जाएगा। Y सह-समन्वय समान रहेगा।

    अनुवाद के लिए प्रतिशत का पता लगाएं:

    x% = (सीएक्स / डब्ल्यू) * 100, वाई% = (साइ / डब्ल्यू) * 100

    स्थिति से ग्रैड आईटीएम के लिए (1.0) पर एक्सडेलटा = 0 से एक्सएंडटाईटा = x% p से वाई डेलटा = 0 से वाई डेलटा = या% पी

  3. मैट्रिक्स का।

    ग्रिडव्यू के केंद्र का वाई समन्वय इस मद के करीब है, इसलिए हमें घटाया जाना है (heightOfTheItem + spacingBetweenItems)।

    अब Cy = Cy - (ऊँचाई TheThetem + spacingBetweenItems)

    इस मामले में केवल वाई समन्वय बदल जाएगा। x सह-समन्वय वस्तु के समान (0,0) पर रहेगा।

    अनुवाद के लिए प्रतिशत का पता लगाएं

    x% = (सीएक्स / डब्ल्यू) * 100, Y% = (साइ / डब्ल्यू) * 100

    आइटम से एक्सडेलटा = 0 से एक्सडेलटा = x% p से वाई डील्टा = 0 से वाईडेलटा = या% पी

  4. मैट्रिक्स की स्थिति (1,1) पर ग्रिड-आइटम के लिए।

    ग्रिडव्यू के केंद्र के एक्स समन्वयन इस आइटम के करीब है, इसलिए हमें (चौड़ाई ओफ़ईआईटीआईटम + स्पेसिंगबेटिनइटम) घटा देना होगा ।

    अब सीएक्स = सीएक्स - (चौड़ाई ओफ़ईईईआईटीएम + स्पेसिंगबेटिन इटम्स)

    ग्रिडव्यू के केंद्र का वाई समन्वय इस मद के करीब है, इसलिए हमें कटौती (heightOfTheItem +

    अनुवाद के लिए -

    x% = (सीएक्स / डब्ल्यू) * 100, वाई% = (साइ / डब्ल्यू) * 100;

    आइटम से एक्सडेलटा = 0 से एक्सडेलटा = x% p fromYDelta = 0 toYDelta = y% p

    इस तरह से सभी वस्तुओं के लिए x% और y% के मानों की गणना करें GridView में।

    केंद्रीय आइटम से परे एक पंक्ति में आइटम के लिए toxDelta होगा -वे।

    केंद्रीय आइटम से परे एक कॉलम में आइटम toDDELTA होगा - Ve।

    केंद्र में वस्तुओं के अधिक सटीक संरेखण के लिए (एनीमेशन के बाद) ग्रिडव्यू के केंद्र में प्रत्येक आइटम के केंद्र के समन्वयन को जोड़ने और घटाने पर विचार करें। > आइटम को अपनी मूल स्थिति से केंद्र तक ट्रांसफ़ॉर्म करने के बाद, यदि आप उन्हें अपनी मूल स्थिति में वापस अनुवाद करना चाहते हैं तो सिर्फ डेल्टा -एव के मूल्यों को बनाएं।

    यह मैंने किया है (0,0) पर ग्रिडव्यू आइटम:

      & lt; अनुवाद करें एंड्रॉइड: अवधि = " 600 "एंड्रॉइड: fromXDelta =" 0% p "एंड्रॉइड: fromYDelta =" 0% p "एंड्रॉइड: toXDelta =" - 7.8% p "एंड्रॉइड: toDDelta =" 33.40% p "/ & gt; & Lt; एंड्रॉइड अनुवाद: अवधि = "600" एंड्रॉइड: fromXDelta = "0% p" एंड्रॉइड: fromYDelta = "0% p" एंड्रॉइड: startoffset = "1050" एंड्रॉइड: toXDelta = "7.8% p" एंड्रॉइड: toYDelta = "- 33.40% पी "/ & gt;   



Comments

Popular posts from this blog

c++ - Cmake produces file extensions in static library archives -

c# - Roxy file manager in MVC doesn't accept session path -

c# - Check if a NumericUpDown has no value -