Winscope एक वेब टूल है. इसकी मदद से, उपयोगकर्ता ऐनिमेशन और ट्रांज़िशन के दौरान और बाद में, कई सिस्टम सेवाओं की स्थितियों को रिकॉर्ड, फिर से चला सकते हैं, और उनका विश्लेषण कर सकते हैं. Winscope, ट्रैक फ़ाइल में सिस्टम की सभी ज़रूरी सेवाओं की स्थितियों को रिकॉर्ड करता है. ट्रैस फ़ाइल के साथ Winscope यूज़र इंटरफ़ेस (यूआई) का इस्तेमाल करके, हर ऐनिमेशन फ़्रेम के लिए इन सेवाओं की स्थिति की जांच की जा सकती है. इसके लिए, स्क्रीन रिकॉर्डिंग के साथ या उसके बिना, ट्रांज़िशन को फिर से चलाकर, उनमें आगे बढ़कर, और उन्हें डीबग करके ऐसा किया जा सकता है.
इस्तेमाल किए जा सकने वाले ट्रेस
Winscope की मदद से, सिस्टम की सेवा की स्थितियों के अलग-अलग ट्रेस या क्रम को इकट्ठा करके, विज़ुअल तौर पर दिखाया जा सकता है. इन ट्रेस को, इस्तेमाल के अलग-अलग उदाहरणों के हिसाब से कॉन्फ़िगर किया जा सकता है. इनमें कम ओवरहेड से लेकर ज़्यादा जानकारी देने वाले उदाहरण शामिल हैं. Winscope में ये ट्रैस काम करते हैं:
- EventLog:
EventLog
का इस्तेमाल करके, सिस्टम डाइग्नोस्टिक्स इवेंट का रिकॉर्ड इकट्ठा करें. Winscope में इस जानकारी का इस्तेमाल सिर्फ़ सीयूजे मार्किंग की पहचान करने और उन्हें दिखाने के लिए किया जाता है. - IME: इनपुट के तरीके के संपादक (IME) की पाइपलाइन से इवेंट ट्रैक करें. इनमें IMS, IMMS, और IME क्लाइंट शामिल हैं.
- इनपुट: इनपुट इवेंट की पाइपलाइन के अलग-अलग हिस्सों से इनपुट इवेंट ट्रैक करें.
- ProtoLog: सिस्टम सेवाओं से ProtoLog मैसेज और क्लाइंट प्रोसेस में चल रही सिस्टम सेवाओं का कोड इकट्ठा करें.
- स्क्रीन रिकॉर्डिंग: ट्रेस के साथ-साथ स्क्रीन रिकॉर्डिंग भी इकट्ठा करें.
- शेल ट्रांज़िशन: विंडो और गतिविधि ट्रांज़िशन सिस्टम की जानकारी रिकॉर्ड करें.
- SurfaceFlinger: SurfaceFlinger से मिले ट्रैस इकट्ठा करें. इनमें, प्लैटफ़ॉर्म (लेयर) की जानकारी होती है. जैसे, प्लैटफ़ॉर्म की स्थिति, बफ़र, और कॉम्पोज़िशन.
- लेन-देन: कंपोज़िशन के लिए
SurfaceControl
का इस्तेमाल करके, SurfaceFlinger को मिले एटमिक बदलावों के सेट को ट्रैक करें. - ViewCapture: सिस्टम विंडो के उन सभी व्यू की प्रॉपर्टी कैप्चर करें जिनमें ViewCapture की सुविधा काम करती है. जैसे, सिस्टम यूज़र इंटरफ़ेस (यूआई) और लॉन्चर.
- विंडो मैनेजर: विंडो मैनेजर की उन स्थितियों को ट्रैक करें जिनमें विंडो से जुड़ी जानकारी शामिल हो. जैसे, इनपुट और फ़ोकस इवेंट, स्क्रीन ओरिएंटेशन, ट्रांज़िशन, ऐनिमेशन, पोज़िशनिंग, और ट्रांसफ़ॉर्मेशन.
इस्तेमाल किए जा सकने वाले डंप
Winscope, स्टेटस डंप इकट्ठा और दिखा सकता है. ये डिवाइस की स्थिति के स्नैपशॉट होते हैं, जिन्हें उपयोगकर्ता के तय किए गए खास समय पर लिया जाता है. ट्रेस की तरह, डंप सिर्फ़ उन समय लिए जाते हैं जब उपयोगकर्ता तय करता है. ऐसा इसलिए किया जाता है, ताकि परफ़ॉर्मेंस और जानकारी पर असर न पड़े. ट्रेस, डिवाइस के इस्तेमाल के दौरान लगातार इकट्ठा किए जाते हैं और इनका असर परफ़ॉर्मेंस पर पड़ सकता है. इससे, किसी खास समय पर डिवाइस की स्थिति का ज़्यादा फ़ोकस और बेहतर विश्लेषण किया जा सकता है. Winscope में ये डंप इस्तेमाल किए जा सकते हैं:
- विंडो मैनेजर: विंडो मैनेजर की किसी एक स्थिति को डंप करें.
- SurfaceFlinger: SurfaceFlinger का एक स्नैपशॉट डंप करें.
- स्क्रीनशॉट: डंप के साथ-साथ स्क्रीनशॉट भी इकट्ठा करें.
संसाधन
Winscope बनाने और चलाने के बारे में जानकारी पाने के लिए, Winscope चलाएं लेख पढ़ें.
ट्रैक रिकॉर्ड करने के बारे में जानने के लिए, ट्रैक रिकॉर्ड करना लेख पढ़ें.
Winscope के वेब यूज़र इंटरफ़ेस (यूआई) का इस्तेमाल करके, ट्रेस लोड करने का तरीका जानने के लिए, ट्रेस लोड करें लेख पढ़ें.
ट्रेस का विश्लेषण करने के बारे में जानकारी के लिए, ट्रेस का विश्लेषण करें लेख पढ़ें.
उदाहरण
यहां दिए गए उदाहरण में, फ़्लिकर टेस्ट में हुई गड़बड़ी और उपयोगकर्ता की ओर से बताए गए गड़बड़ी को डीबग करने का तरीका बताया गया है.
फ़्लिकर की जांच पूरी न हो पाना
इस उदाहरण में, फ़्लिकर टेस्ट में हुई गड़बड़ी को डीबग करने के लिए, Winscope का इस्तेमाल करने का तरीका बताया गया है.
जांच पूरी न हो पाने की वजह का पता लगाना
समस्या का टाइप पता करने और टेस्ट में हुई गड़बड़ी के मैसेज की जांच करने के लिए, यह तरीका अपनाएं.
टेस्ट और क्लास के नाम की जांच करके, समस्या का टाइप तय करें.
टेस्ट और क्लास का नाम:
FlickerTestsNotification com.android.server.wm.flicker.notification.OpenAppFromLockscreenNotificationColdTest#appLayerBecomesVisible[ROTATION_0_GESTURAL_NAV]
समस्या प्रकार:
सीयूजे का मतलब है, लॉक स्क्रीन पर सूचना (
OpenAppFromLockscreenNotificationColdTest
) से ऐप्लिकेशन को लॉन्च करना.टेस्ट में यह उम्मीद की जाती है कि ऐप्लिकेशन दिखेगा (
#appLayerBecomesVisible
).
टेस्ट में हुई गड़बड़ी के मैसेज की जांच करें. इसमें, गड़बड़ी के बारे में पूरी जानकारी मिलती है. जैसे:
- अनुमानित नतीजे और दिखने वाले असल नतीजे की तुलना
- गड़बड़ी होने के समय की जानकारी देने वाले टाइमस्टैंप
- गड़बड़ी से जुड़े आर्टफ़ैक्ट या फ़ाइल का नाम
- गड़बड़ी को समझने और डीबग करने के लिए, काम के कॉन्टेक्स्ट में अतिरिक्त जानकारी
android.tools.flicker.subject.exceptions.IncorrectVisibilityException: com.android.server.wm.flicker.testapp/com.android.server.wm.flicker.testapp.NotificationActivity# should be visible Where? Timestamp(UNIX=2024-05-10T11:04:14.227572545(1715339054227572545ns), UPTIME=37m21s184ms79178ns(2241184079178ns), ELAPSED=0ns) What? Expected: com.android.server.wm.flicker.testapp/com.android.server.wm.flicker.testapp.NotificationActivity# Actual: [e636ecd com.android.server.wm.flicker.testapp/com.android.server.wm.flicker.testapp.NotificationActivity#3457: Buffer is empty, Visible region calculated by Composition Engine is empty, com.android.server.wm.flicker.testapp/com.android.server.wm.flicker.testapp.NotificationActivity#3458: Visible region calculated by Composition Engine is empty] Other information Artifact: FAIL__OpenAppFromLockscreenNotificationColdTest_ROTATION_0_GESTURAL_NAV.zip Check the test run artifacts for trace files at android.tools.flicker.subject.layers.LayerTraceEntrySubject.isVisible(LayerTraceEntrySubject.kt:187) at android.tools.flicker.subject.layers.LayersTraceSubject$isVisible$1$1.invoke(LayersTraceSubject.kt:151) at android.tools.flicker.subject.layers.LayersTraceSubject$isVisible$1$1.invoke(LayersTraceSubject.kt:150) at android.tools.flicker.assertions.NamedAssertion.invoke(NamedAssertion.kt:32) at android.tools.flicker.assertions.CompoundAssertion.invoke(CompoundAssertion.kt:42) at android.tools.flicker.assertions.AssertionsChecker.test(AssertionsChecker.kt:79) at android.tools.flicker.subject.FlickerTraceSubject.forAllEntries(FlickerTraceSubject.kt:59) at android.tools.flicker.assertions.AssertionDataFactory$createTraceAssertion$closedAssertion$1.invoke(AssertionDataFactory.kt:46) at android.tools.flicker.assertions.AssertionDataFactory$createTraceAssertion$closedAssertion$1.invoke(AssertionDataFactory.kt:43) at android.tools.flicker.assertions.AssertionDataImpl.checkAssertion(AssertionDataImpl.kt:33) at android.tools.flicker.assertions.ReaderAssertionRunner.doRunAssertion(ReaderAssertionRunner.kt:35) at android.tools.flicker.assertions.ReaderAssertionRunner.runAssertion(ReaderAssertionRunner.kt:29) at android.tools.flicker.assertions.BaseAssertionRunner.runAssertion(BaseAssertionRunner.kt:36) at android.tools.flicker.legacy.LegacyFlickerTest.doProcess(LegacyFlickerTest.kt:59) at android.tools.flicker.assertions.BaseFlickerTest.assertLayers(BaseFlickerTest.kt:89) at com.android.server.wm.flicker.notification.OpenAppTransition.appLayerBecomesVisible_coldStart(OpenAppTransition.kt:51) at com.android.server.wm.flicker.notification.OpenAppFromNotificationColdTest.appLayerBecomesVisible(OpenAppFromNotificationColdTest.kt:64)
इस आउटपुट सैंपल से यह पता चलता है:
यह समस्या
2024-05-10T11:04:14.227572545
पर होती है.NotificationActivity
दिखना चाहिए, लेकिन नहीं दिख रहा है.डीबग करने के लिए ट्रेस वाली आर्टफ़ैक्ट फ़ाइल का नाम
FAIL__OpenAppFromLockscreenNotificationColdTest_ROTATION_0_GESTURAL_NAV
है.
डीबग
फ़्लिकर की वजह का पता लगाने के लिए, यह तरीका अपनाएं:
ट्रैक की गई फ़ाइलें डाउनलोड करें और उन्हें Winscope में लोड करें. Winscope, SurfaceFlinger के अपने-आप चुने जाने की सुविधा के साथ खुलता है:
पहली इमेज. SurfaceFlinger व्यू वाला Winscope का लैंडिंग पेज.
समस्या वाले टाइमस्टैंप पर जाने के लिए, अपवाद वाले मैसेज के टाइमस्टैंप को कॉपी करके, टाइमस्टैंप फ़ील्ड में चिपकाएं. टाइमस्टैंप को, इंसान के पढ़ने लायक फ़ॉर्मैट (
2024-05-10T11:04:14.227572545
) में कॉपी करके पहले फ़ील्ड में चिपकाया जा सकता है. इसके अलावा, टाइमस्टैंप को नैनोसेकंड (1715339054227572545ns
) में कॉपी करके दूसरे फ़ील्ड में चिपकाया जा सकता है.दूसरी इमेज. टाइमस्टैंप डायलॉग.
पिछले फ़्रेम पर जाने के लिए, लेफ़्ट ऐरो बटन दबाएं. इस स्थिति में, NotificationActivity ऐप्लिकेशन वीडियो में सही तरीके से दिखता है. साथ ही, ऐप्लिकेशन और स्प्लैश स्क्रीन, दोनों के प्लैटफ़ॉर्म दिखते हैं. इनके बारे में 3D व्यू में हरे रंग के रेक्टैंगल और हैरारकी एलिमेंट पर V चिप से पता चलता है.
ऐप्लिकेशन और स्प्लैश स्क्रीन के सरफ़ेस के नाम ये हैं:
com.android.server.wm.flicker.testapp/com.android.server.wm.flicker.testapp.NotificationActivity#3458` Splash Screen com.android.server.wm.flicker.testapp#3453
इससे पता चलता है कि स्क्रीन का काला पड़ना, ऐप्लिकेशन के लॉन्च होने के दौरान हुआ था. साथ ही, स्प्लैश स्क्रीन अब भी दिख रही है, इसलिए यह इवेंट ऐप्लिकेशन के लॉन्च होने के दौरान हुआ है:
तीसरी इमेज. ऐप्लिकेशन लॉन्च होने पर.
अगले फ़्रेम पर वापस जाने के लिए, राइट ऐरो बटन दबाएं. रेक्ट व्यू में, ऐप्लिकेशन के बजाय स्क्रीन पर
NotificationShade
दिखता है. इस फ़्रेम में ये प्लैटफ़ॉर्म दिखते हैं:- स्क्रीन डेकोर ओवरले (ऊपर और नीचे)
- नेविगेशन बार
पॉइंटर की जगह (स्क्रीन रिकॉर्डिंग से)
चौथी इमेज. फ़्लिकर गतिविधि.
हैरारकी व्यू में, ऐप्लिकेशन गतिविधि चुनें. अगर आपको यह विकल्प नहीं मिल रहा है, तो सिर्फ़ V दिखाएं को टॉगल करें. इसके बाद, प्रॉपर्टी व्यू की जांच करें.
ऐप्लिकेशन के प्लैटफ़ॉर्म का नाम:
com.android.server.wm.flicker.testapp/com.android.server.wm.flicker.testapp.NotificationActivity#3458`
पांचवीं इमेज. ऐप्लिकेशन प्रॉपर्टी.
भले ही, ऐप्लिकेशन गतिविधि को 'दिख रहा है' और 'अस्पष्ट है' पर सेट किया गया हो, लेकिन
Invisible due to: null visible region
गड़बड़ी की वजह से, प्लैटफ़ॉर्म नहीं दिख रहा है. ऐसा इसलिए होता है, क्योंकि कॉम्पोज़िशन के दौरान, उसके सामने कोई ऐसा ऑब्जेक्ट रखा गया था जिससे रोशनी नहीं आती. यह अनुमान इस बात से लगाया गया है कि 3D व्यू मेंNotificationShade
रेक्टैंगल,NotificationActivity
रेक्टैंगल के सामने है. साथ ही, दिखने वाला (हरा)NotificationShade
, चुनी गई लेयर हो सकता है.इस अनुमान की पुष्टि करने के लिए, मौजूदा फ़्रेम पर दिख रही
NotificationShade
सतह चुनें और उसकी प्रॉपर्टी देखें. फ़्लैग कोOPAQUE|ENABLE_BACKPRESSURE (0x102)
पर सेट किया गया है.NotificationShade
सर्फ़ेस का नामNotificationShade#3447
है. इसके बाद, पिछले फ़्रेम (फ़्लिकर से पहले) पर वापस जाने के लिए, बाईं ओर मौजूद ऐरो दबाएं औरNotificationShade
प्लैटफ़ॉर्म की प्रॉपर्टी की फिर से जांच करें. ध्यान दें किOPAQUE
के बजाय, प्लैटफ़ॉर्म पर सिर्फ़ENABLE_BACKPRESSURE (0x100)
फ़्लैग है. इससे यह पुष्टि होती है कि ऐप्लिकेशन लॉन्च होने से पहले,NotificationShade
धुंधला हो जाता है.NotificationShade
,NotificationActivity
के सामने होने की वजह से, ऐप्लिकेशन नहीं दिखता.NotificationShade
का रंग काला है, इसलिए स्क्रीन कुछ समय के लिए काली हो जाती है. इससे फ़्लिकर होता है.कोड में पता लगाएं कि
NotificationShade
बहुत जल्दी धुंधला क्यों हो जाता है.
उपयोगकर्ता की ओर से रिपोर्ट की गई गड़बड़ी
उपयोगकर्ताओं की ओर से बताई गई गड़बड़ियों को डीबग करना मुश्किल हो सकता है, क्योंकि उनमें अक्सर ज़्यादा जानकारी नहीं होती. फ़्लिकर टेस्ट में होने वाली गड़बड़ियों के विपरीत, उपयोगकर्ताओं की शिकायत में आम तौर पर समस्या के बारे में कम शब्दों में जानकारी दी जाती है. फ़्लिकर टेस्ट में, टाइमस्टैंप, एलिमेंट की जानकारी, और स्क्रीन रिकॉर्डिंग जैसी जानकारी मिलती है.
हमारे केस स्टडी में, सिर्फ़ टाइटल स्प्लिट स्क्रीन से ऐप्लिकेशन को फिर से खोलने पर स्क्रीन फ़्लिकर हुई और 18 अप्रैल, 2024 को दोपहर 3:51 बजे GMT-04:00 का अनुमानित टाइमस्टैंप दिया गया है.
उपयोगकर्ता की शिकायत की गई किसी गड़बड़ी को डीबग करने के लिए, यह तरीका अपनाएं:
Winscope में ट्रेस फ़ाइल लोड करें. Winscope, SurfaceFlinger के साथ अपने-आप खुलता है.
छठी इमेज. SurfaceFlinger व्यू वाला Winscope का लैंडिंग पेज.
उपयोगकर्ता ने जिस टाइमस्टैंप की शिकायत की है उस पर जाएं. इस मामले में,
3:50 PM GMT-04:00
पर जाएं. इसके लिए, टाइमस्टैंप वाले फ़ील्ड में15:50:00
डालें.सातवीं इमेज. टाइमस्टैंप डायलॉग.
स्क्रीन पर क्या ड्रॉ किया गया है, यह पता लगाने के लिए रेक्ट व्यू का इस्तेमाल करें. बेहतर व्यू के लिए, रोटेशन स्लाइडर का इस्तेमाल करके, रेक्ट के पर्सपेक्टिव को बदलें. क्रम व्यू में, सिर्फ़ V और फ़्लैट को मार्क करने पर, वॉलपेपर, स्क्रीन डेकोर ओवरले, लेटरबॉक्स, लॉन्चर, संपर्क, और डायलर प्लैटफ़ॉर्म दिखते हैं.
पैकेज के नाम ये हैं:
लॉन्चर:
com.google.android.apps.nexuslauncher/com.google.android.apps.nexuslauncher.NexusLauncherActivity#40602
संपर्क:
com.google.android.contacts/com.android.contacts.activities.PeopleActivity#40565
डायलर:
com.google.android.dialer/com.google.android.dialer.extensions.GoogleDialtactsActivity#40564
दिखने वाले प्लैटफ़ॉर्म (हरे रंग के रेक्टैंगल) के अलावा, एक स्लेटी रंग का रेक्टैंगल भी दिखता है. यह अज्ञात डिसप्ले नाम के डिसप्ले एरिया प्लैटफ़ॉर्म को दिखाता है. बेहतर तरीके से देखने के लिए,
ScreenDecorHwcOverlay#64
प्लैटफ़ॉर्म के बगल में मौजूद () पर क्लिक करें. इससे, उस प्लैटफ़ॉर्म से जुड़ा रेक्ट छिप जाएगा और उसके पीछे मौजूद प्लैटफ़ॉर्म दिखने लगेंगे. हम विश्लेषण के लिए ओवरले हटा देते हैं, क्योंकि यह उपयोगकर्ता को नहीं दिखता. साथ ही, इसे फ़्लिकर करने वाले ऐनिमेशन के तौर पर रिपोर्ट नहीं किया जाएगा.
आठवीं इमेज. उपयोगकर्ता की शिकायत.
स्प्लिट स्क्रीन व्यू में कौनसे प्लैटफ़ॉर्म शामिल हैं, यह पता लगाने के बाद ट्रांज़िशन ट्रेस का इस्तेमाल करके, उपयोगकर्ता की अलग-अलग कार्रवाइयों को देखें और फ़्लिकर का पता लगाएं. चलाए गए ट्रांज़िशन की सूची देखने के लिए, Winscope में ट्रांज़िशन टैब पर क्लिक करें:
नौवीं इमेज. ट्रांज़िशन.
इस फ़्रेम के दौरान चलाया गया ट्रांज़िशन, नीले रंग में हाइलाइट किया गया है. इस मामले में, ट्रांज़िशन फ़्लैग में
TRANSIT_FLAG_IS_RECENTS
शामिल है, जिससे पता चलता है कि उपयोगकर्ता हाल ही में इस्तेमाल की गई ऐप्लिकेशन की स्क्रीन पर जा रहा है.उस समय पर जाने के लिए, डिस्पैच का समय कॉलम (इस मामले में
2024-04-18, 15:50:57.205
) में मौजूद लिंक पर क्लिक करें. इसके बाद, Surface Flinger टैब में जाकर, रेक्ट की पुष्टि करें. ट्रांज़िशन के दौरान, डिवाइस की स्थिति सही है या नहीं, इसकी पुष्टि करें. इसके लिए, राइट ऐरो बटन का इस्तेमाल करके ट्रांज़िशन की प्रक्रिया को आगे बढ़ाएं और रेक्ट को देखें.लॉन्चर 15:50:57.278 पर दिखता है, लेकिन ऐनिमेशन तब शुरू नहीं होता. वॉलपेपर पहले से ही दिख रहा है, क्योंकि स्प्लिट-स्क्रीन ऐप्लिकेशन (डिवाइडर) के बीच कुछ नहीं है. इससे पहले के एक फ़्रेम (15:50:57.212) में, वॉलपेपर नहीं दिख रहा है और डिवाइडर दिख रहा है. ऐनिमेशन न होने पर, स्प्लिट-स्क्रीन ऐसा ही दिखती है.
10वीं इमेज. फ़्लिकर इवेंट से पहले की स्क्रीन.
अगला ट्रांज़िशन देखने के लिए, सीधे टाइमलाइन पर क्लिक करें. SurfaceFlinger की स्थितियों को हल्के नीले रंग के ब्लॉक की एक पंक्ति से दिखाया जाता है. ट्रांज़िशन को गुलाबी ब्लॉक की एक पंक्ति से दिखाया जाता है.
11वीं इमेज. पहला ट्रांज़िशन खत्म होने का समय.
अगले ट्रांज़िशन की शुरुआती पोज़िशन पर मौजूद, SurfaceFlinger लाइन पर क्लिक करें. इमेज 11 में, कर्सर की वर्टिकल पोज़िशन को नीली पतली लाइन से दिखाया गया है. SurfaceFlinger लाइन का हल्का नीला रंग, उसकी हॉरिज़ॉन्टल पोज़िशन दिखाता है. राइट ऐरो बटन का इस्तेमाल करके ट्रांज़िशन को धीरे-धीरे देखें और देखें कि फ़्लिकर होता है या नहीं. पक्का करें कि इस ट्रांज़िशन के लिए डिवाइस सही दिख रहा हो.
अगले ट्रांज़िशन को स्किप करें, क्योंकि इसकी अवधि बहुत कम है. इसलिए, इसमें फ़्लिकर होने की संभावना नहीं है. इसके बजाय, अगले लंबे ट्रांज़िशन की शुरुआत वाली जगह पर, SurfaceFlinger लाइन में टाइमलाइन पर क्लिक करें. इसकी जानकारी, नीचे दी गई इमेज में कर्सर से दी गई है.
12वीं इमेज. दूसरा ट्रांज़िशन खत्म.
इस ट्रांज़िशन के दौरान,
15:51:13.239
पर जाएं और देखें कि दोनों ऐप्लिकेशन, संपर्क, और डायलर के लिएSplash Screen
लेयर, डिसप्ले की एक ही तरफ़ हैं:13वीं इमेज. स्प्लैश स्क्रीन.
बताएं कि कौनसा ऐप्लिकेशन गलत जगह पर है. ns इनपुट फ़ील्ड के बगल में मौजूद फ़्लैग आइकॉन पर क्लिक करके, अपनी मौजूदा पोज़िशन पर बुकमार्क जोड़ें. इससे, बाद में इस फ़्रेम पर वापस जाने में मदद मिलेगी.
इमेज 14. बुकमार्क जोड़ें.
सीधे टाइमलाइन पर क्लिक करके, ट्रांज़िशन के आखिर में मौजूद किसी फ़्रेम पर जाएं. उदाहरण के लिए,
15:51:13.859
पर. यहां दोनों ऐप्लिकेशन अब अपनी आखिरी जगह पर हैं. डायलर बाईं ओर और संपर्क दाईं ओर हैं:15वीं इमेज. फ़ाइनल स्प्लिट स्क्रीन.
फ़्लिकर वाले फ़्रेम पर वापस जाने के लिए, टाइमलाइन में बुकमार्क के फ़्लैग पर क्लिक करें.
16वीं इमेज. टाइमलाइन को बुकमार्क करें.
दोनों ऐप्लिकेशन दाईं ओर हैं. इससे पता चलता है कि डायलर ऐप्लिकेशन गलत जगह पर है.
डायलर की प्रॉपर्टी देखने के लिए, डायलर की स्प्लैश स्क्रीन पर क्लिक करें. चुनी गई प्रॉपर्टी व्यू में, खास तौर पर इसकी ट्रांसफ़ॉर्म प्रॉपर्टी देखें.
17वीं इमेज. प्रॉपर्टी बदलें.
कैलकुलेट किया गया ट्रांसफ़ॉर्म, इस प्लैटफ़ॉर्म पर लागू होता है, लेकिन इसे इस लेवल के तौर पर सेट नहीं किया जाता. कैलकुलेट किए गए और अनुरोध किए गए कॉलम की वैल्यू अलग-अलग होती हैं. इससे पता चलता है कि ट्रांसफ़ॉर्म को पैरंट प्लैटफ़ॉर्म से इनहेरिट किया जा रहा है.
हैरारकी का पूरा ट्री दिखाने के लिए, हैरारकी व्यू में फ़्लैट से चुने हुए का निशान हटाएं. इसके बाद, ऐप्लिकेशन के प्लैटफ़ॉर्म के पैरंट नोड पर तब तक जाएं, जब तक कैलकुलेट किया गया और अनुरोध किया गया ट्रांसफ़ॉर्म एक जैसे न हो जाएं. इससे,
Surface(name=Task=7934)/@0x1941191_transition-leash#40670
प्लैटफ़ॉर्म पर अनुरोध किया गया ट्रांसफ़ॉर्म दिखेगा.पुष्टि करें कि ट्रांसफ़ॉर्म को पहली बार कब सेट किया गया था और किस वैल्यू पर सेट किया गया था. टाइटल के बगल में मौजूद आइकॉन पर क्लिक करके, चुनी गई प्रॉपर्टी को छोटा करें:
18वीं इमेज. चुनी गई प्रॉपर्टी को छोटा करें.
इस फ़्रेम में बदली जा रही प्रॉपर्टी को हाइलाइट करने के लिए, प्रोटो डंप व्यू में बदलाव दिखाएं को चुनें. प्रॉपर्टी को फ़िल्टर करने के लिए, टेक्स्ट खोज फ़ील्ड में
transform
टाइप करें:19वीं इमेज. अंतर दिखाएं.
transition-leash
के लिए, इस फ़्रेम में ट्रांसफ़ॉर्म कोIDENTITY
सेSCALE|TRANSLATE|ROT_270
पर सेट किया गया है.इस जानकारी से पता चलता है कि फ़्लिकर तब हुआ, जब डायलर स्प्लिट स्क्रीन ऐप्लिकेशन के ऐनिमेशन लीश पर ट्रांसफ़ॉर्म लागू किया गया था.
20वीं इमेज. फ़्लिकर की पहचान.
कोड में यह पता लगाएं कि यह ट्रांसफ़ॉर्मेशन, स्प्लिट स्क्रीन ट्रांज़िशन लीश पर क्यों सेट है.