2015-10-26 19 views
33

Moja aplikacja łamie ograniczenie, gdy przedstawiam pasek statusu "Wezwanie", naciskając Command + Y w symulatorze. Dzieje się tak tylko za pierwszym razem, gdy prezentuje pasek wywołania. Wszystko wygląda jak to ma, ale drukuje wylogowanie następuje:| - (20) - Ograniczenie [UIInputSetContainerView łamie się, gdy pasek stanu wezwania staje się widoczny

Unable to simultaneously satisfy constraints. 
    Probably at least one of the constraints in the following list is one you don't want. 
    Try this: 
     (1) look at each constraint and try to figure out which you don't expect; 
     (2) find the code that added the unwanted constraint or constraints and fix it. 
(
    "<NSLayoutConstraint:0x7fb4cb9b2b60 V:|-(20)-[UIInputSetContainerView:0x7fb4cb9b1190] (Names: '|':UITextEffectsWindow:0x7fb4cba003f0)>", 
    "<NSLayoutConstraint:0x7fb4cb942100 'UIInputWindowController-top' V:|-(0)-[UIInputSetContainerView:0x7fb4cb9b1190] (Names: '|':UITextEffectsWindow:0x7fb4cba003f0)>" 
) 

Will attempt to recover by breaking constraint 
<NSLayoutConstraint:0x7fb4cb9b2b60 V:|-(20)-[UIInputSetContainerView:0x7fb4cb9b1190] (Names: '|':UITextEffectsWindow:0x7fb4cba003f0)> 

Make a symbolic breakpoint at UIViewAlertForUnsatisfiableConstraints to catch this in the debugger. 
The methods in the UIConstraintBasedLayoutDebugging category on UIView listed in <UIKit/UIView.h> may also be helpful. 

To stos wywołań gdy łamie dla UIViewAlertForUnsatisfiableConstraints:

* thread #1: tid = 0x17582f, 0x0000000109bbb4c6 UIKit`UIViewAlertForUnsatisfiableConstraints, queue = 'com.apple.main-thread', stop reason = breakpoint 3.1 
    frame #0: 0x0000000109bbb4c6 UIKit`UIViewAlertForUnsatisfiableConstraints 
    frame #1: 0x0000000109bbb8b2 UIKit`-[UIView(UIConstraintBasedLayout_EngineDelegate) engine:willBreakConstraint:dueToMutuallyExclusiveConstraints:] + 113 
    frame #2: 0x0000000107ea672b Foundation`-[NSISEngine handleUnsatisfiableRowWithHead:body:usingInfeasibilityHandlingBehavior:mutuallyExclusiveConstraints:] + 489 
    frame #3: 0x0000000107d07801 Foundation`-[NSISEngine fixUpValueRestrictionViolationsWithInfeasibilityHandlingBehavior:] + 613 
    frame #4: 0x0000000107d07537 Foundation`-[NSISEngine optimize] + 134 
    frame #5: 0x0000000107d07da4 Foundation`-[NSISEngine withBehaviors:performModifications:] + 245 
    frame #6: 0x0000000109bb5a4b UIKit`-[UIView(AdditionalLayoutSupport) _withAutomaticEngineOptimizationDisabledIfEngineExists:] + 58 
    frame #7: 0x0000000109bb658e UIKit`-[UIView(AdditionalLayoutSupport) updateConstraintsIfNeeded] + 254 
    frame #8: 0x0000000109ba6c46 UIKit`-[UIWindow(UIConstraintBasedLayout) updateConstraintsIfNeeded] + 108 
    frame #9: 0x0000000109bb72a3 UIKit`-[UIView(AdditionalLayoutSupport) _updateConstraintsAtEngineLevelIfNeeded] + 272 
    frame #10: 0x00000001093979b3 UIKit`-[UIView(Hierarchy) layoutBelowIfNeeded] + 845 
    frame #11: 0x000000010936eb8b UIKit`-[UIWindow handleStatusBarChangeFromHeight:toHeight:] + 1284 
    frame #12: 0x0000000109703b5b UIKit`-[UITextEffectsWindow handleStatusBarChangeFromHeight:toHeight:] + 100 
    * frame #13: 0x00000001093726a7 UIKit`+[UIWindow _noteStatusBarHeightChanged:oldHeight:forAutolayoutRootViewsOnly:] + 364 
    frame #14: 0x0000000109303a52 UIKit`-[UIApplication statusBar:willAnimateFromHeight:toHeight:duration:animation:] + 265 
    frame #15: 0x00000001099115bb UIKit`-[UIStatusBar _requestStyleAttributes:animationParameters:forced:] + 885 
    frame #16: 0x0000000109910fbf UIKit`-[UIStatusBar requestStyle:animationParameters:forced:] + 437 
    frame #17: 0x0000000109910d0d UIKit`-[UIStatusBar requestStyle:animated:forced:] + 90 
    frame #18: 0x00000001099160a6 UIKit`-[UIStatusBar statusBarServer:didReceiveStyleOverrides:] + 56 
    frame #19: 0x0000000109904b05 UIKit`_UIStatusBarReceivedStyleOverrides + 45 
    frame #20: 0x0000000109909058 UIKit`_XReceivedStyleOverrides + 33 
    frame #21: 0x0000000110d67fa8 AppSupport`migHelperRecievePortCallout + 208 
    frame #22: 0x000000010896c289 CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 41 
    frame #23: 0x000000010896c1f9 CoreFoundation`__CFRunLoopDoSource1 + 473 
    frame #24: 0x0000000108961970 CoreFoundation`__CFRunLoopRun + 2272 
    frame #25: 0x0000000108960e08 CoreFoundation`CFRunLoopRunSpecific + 488 
    frame #26: 0x000000010e360ad2 GraphicsServices`GSEventRunModal + 161 
    frame #27: 0x00000001092f330d UIKit`UIApplicationMain + 171 
    frame #28: 0x00000001074e252f AppName`main(argc=1, argv=0x00007fff5872e688) + 111 at main.m:16 
    frame #29: 0x000000010aa6b92d libdyld.dylib`start + 1 
    frame #30: 0x000000010aa6b92d libdyld.dylib`start + 1 

Czy masz jakiś pomysł, dlaczego przerwach ograniczające? Nie dodałem żadnych ograniczeń do UIInputSetContainerView, UITextEffectsWindow ani UIInputWindowController.

EDIT: Moje pytanie zostało oznaczone jako możliwy duplikat, ale ja nie polecić albo zgodzić się z the answer że jest zaopatrzony w other question. Usunięcie tego ostrzeżenia jest bardzo ryzykowne, ponieważ usuwa ograniczenia własne Apple. Nie polecałbym tego. Dlatego też uważam, że zduplikowana flaga jest niewłaściwa (To pytanie zostało zadane wcześniej i już ma odpowiedź:), ponieważ odpowiedź nie jest tą, której szukam.

+3

Jakie ograniczenia zostały dodane? Podejrzewam, że ograniczenie jest dodawane w środowisku wykonawczym przez system prawdopodobnie ze względu na ustawienie konstruktora interfejsu. Ograniczenia są jednak sprzeczne, jak widać w dzienniku – Lefteris

+0

, czy jest szansa, że ​​pasek stanu przesuwa okno o 20 pikseli w dół? –

+0

@Lefteris Nie dodaje żadnych ograniczeń do widoków, które mają sprzeczne ograniczenia. –

Odpowiedz

16

Wygląda na to, że jest to błąd Apple. Można sprawdzić, że to dzieje się na zupełnie pustym projekcie szablonu:

  • Tworzenie nowego projektu pojedynczy widok
  • Run na iPhone symulatora
  • naciśnij Cmd-Y, aby przełączyć status-bar

Zobaczysz przerwanie więzów.

Radar to droga, którą chciałbym powiedzieć.

+1

Otrzymuję to samo, wspierając wielozadaniowość. Czy ktoś zgłosił radar, który mogę naśladować? – Andrew

+1

@Andrew http://www.openradar.me/24764160 (dla wielozadaniowości) i http://www.openradar.me/24426241 (dla paska stanu). – imgx64

+0

@ imgx64 dzięki, oszukał – Andrew

4

To jest wyraźnie błąd Apple. Domyślam się, że mają błędne ograniczenie, które utrzymuje wysokość paska stanu na 20 pikseli, ale jest zepsute, gdy pasek połączenia rośnie. To nie psuje ani nie wpływa na aplikację, więc na razie można ją bezpiecznie zignorować. Ale Apple Radar powinien być wypełniony.

Powiązane problemy