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# - Roxy file manager in MVC doesn't accept session path -

jsp - No mapping found for HTTP request with URI with annotation config Spring MVC and Jetty -

java - Ajax call to jsp and jsp redirecting to further jsp -