Почему происходит сбой моего UISwitch, когда это tableView.cell.AccessoryView - PullRequest
1 голос
/ 27 мая 2011

Это проблема при использовании MonoTouch.

Я пытаюсь получить TableView с ячейками, которые имеют переключатель UIS, но приложение вылетает при нажатии на переключатель. Просто для тестирования я тоже создал переключатель, который был просто добавлен как подпредставление TableView сам. Единственная разница между обоими коммутаторами - это их родитель. один с родителем TableView работает, тот, который находится в ячейке, как его AccessoryView вылетает при нажатии.

Для тестирования я создал новое приложение для навигации на iPhone (DynUISwitch). Я только отредактировал сгенерированный RootViewController.xib.cs следующим образом:

  using MonoTouch.UIKit;
  using System;
  using System.Drawing;

  using MonoTouch.Foundation;

  namespace DynUISwitch
  {
    partial class RootViewController : UITableViewController
    {
      public RootViewController (IntPtr handle) : base(handle)
      {
      }

      public override void ViewDidLoad ()
      {
        base.ViewDidLoad ();
        RectangleF frame = new RectangleF (100f, 100f, 20f, 20f);
        UISwitch uiSwitch = new UISwitch (frame);
        uiSwitch.ValueChanged += delegate {
          Console.WriteLine ("View Switch value now is {0}", uiSwitch.On);
        };

       this.View.AddSubview (uiSwitch);
        this.TableView.Source = new DataSource (this);
      }
      class DataSource : UITableViewSource
      {
        RootViewController controller;

        public DataSource (RootViewController controller)
        {
          this.controller = controller;
        }
        public override int NumberOfSections (UITableView tableView)
        {
          return 1;
        }
        public override int RowsInSection (UITableView tableview, int section)
        {
          return 1;
        }
        public override UITableViewCell GetCell (UITableView tableView, MonoTouch.Foundation.NSIndexPath indexPath)
        {
          string cellIdentifier = "Cell";
          var cell = tableView.DequeueReusableCell (cellIdentifier);
          if ( cell == null )
          {
            cell = new UITableViewCell (UITableViewCellStyle.Default, cellIdentifier);
          }
          RectangleF frame = new RectangleF (0f, 0f, 20f, 20f);
          UISwitch uiSwitch = new UISwitch (frame);
          uiSwitch.ValueChanged += delegate {
            Console.WriteLine ("Cell Switch value is now {0}", uiSwitch.On);
          };
          cell.AccessoryView = uiSwitch;
          return cell;
        }
      }
    }
  }

При запуске приложения я нажимаю на центральный переключатель UIS, тот, который прямо прикреплен к TableView. Окно вывода приложения показывает, что делегат получает и обрабатывает щелчок. Затем я нажимаю UiSwitch, который является ячейкой. AccessoryView и я сразу же получаю следующий сбой:

StackTrace:

at (wrapper managed-to-native) MonoTouch.UIKit.UIApplication.UIApplicationMain (int,string[],intptr,intptr) <IL 0x0009f, 0xffffffff>
at MonoTouch.UIKit.UIApplication.Main (string[],string,string) [0x00038] in /Users/plasma/Source/iphone/monotouch/UIKit/UIApplication.cs:26
at MonoTouch.UIKit.UIApplication.Main (string[]) [0x00000] in /Users/plasma/Source/iphone/monotouch/UIKit/UIApplication.cs:31
at DynUISwitch.Application.Main (string[]) [0x00000] in /Users/guivho/Mono/Learning/DynUISwitch/Main.cs:14
at (wrapper runtime-invoke) <Module>.runtime_invoke_void_object (object,intptr,intptr,intptr) <IL 0x00050, 0xffffffff>

Собственная трассировка стека:

0   DynUISwitch                         0x000d1965 mono_handle_native_sigsegv + 343
1   DynUISwitch                         0x0000ffb4 mono_sigsegv_signal_handler + 322
2   libSystem.B.dylib                   0x9666e45b _sigtramp + 43
3   ???                                 0xffffffff 0x0 + 4294967295
4   UIKit                               0x01c981b5 -[UIControl sendAction:to:forEvent:] + 67
5   UIKit                               0x01c9a647 -[UIControl(Internal) _sendActionsForEvents:withEvent:] + 527
6   UIKit                               0x01ddcc6d -[UISwitch _onAnimationDidStop:finished:context:] + 201
7   UIKit                               0x01c3a665 -[UIViewAnimationState sendDelegateAnimationDidStop:finished:] + 294
8   UIKit                               0x01c3a4f7 -[UIViewAnimationState animationDidStop:finished:] + 77
9   QuartzCore                          0x030756cb _ZL23run_animation_callbacksdPv + 278
10  QuartzCore                          0x03075589 _ZN2CAL14timer_callbackEP16__CFRunLoopTimerPv + 157
11  CoreFoundation                      0x00e20fe3 __CFRUNLOOP_IS_CALLING_OUT_TO_A_TIMER_CALLBACK_FUNCTION__ + 19
12  CoreFoundation                      0x00e22594 __CFRunLoopDoTimer + 1220
13  CoreFoundation                      0x00d7ecc9 __CFRunLoopRun + 1817
14  CoreFoundation                      0x00d7e240 CFRunLoopRunSpecific + 208
15  CoreFoundation                      0x00d7e161 CFRunLoopRunInMode + 97
16  GraphicsServices                    0x03ede268 GSEventRunModal + 217
17  GraphicsServices                    0x03ede32d GSEventRun + 115
18  UIKit                               0x01c1842e UIApplicationMain + 1160
19  ???                                 0x07fe0744 0x0 + 134088516
20  ???                                 0x07fe067a 0x0 + 134088314
21  ???                                 0x07ef2b96 0x0 + 133114774
22  ???                                 0x07ef2ae2 0x0 + 133114594
23  ???                                 0x07ef2b6d 0x0 + 133114733
24  DynUISwitch                         0x0000fd6f mono_jit_runtime_invoke + 1332
25  DynUISwitch                         0x001ee239 mono_runtime_invoke + 137
26  DynUISwitch                         0x001f0920 mono_runtime_exec_main + 669
27  DynUISwitch                         0x001efd0a mono_runtime_run_main + 843
28  DynUISwitch                         0x000a3c62 mError connecting stdout and stderr (127.0.0.1:10001)
ono_jit_exec + 200
29  DynUISwitch                         0x002a25eb main + 3838
30  DynUISwitch                         0x000030c9 _start + 208
31  DynUISwitch                         0x00002ff8 start + 40
32  ???                                 0x00000002 0x0 + 2

Отладочная информация из gdb:

/tmp/mono-gdb-commands.nzt3EM:1: Error in sourced command file:
unable to debug self

=================================================================
Got a SIGSEGV while executing native code. This usually indicates
a fatal error in the mono runtime or one of the native libraries
used by your application.
=================================================================

Я делал подобные вещи в приложении Objective-C / XCode (имея UIS-переключатель как AccessoryView для TableCell).

Любые предложения, почему он не работает в приведенном выше демонстрационном приложении?

Ответы [ 2 ]

2 голосов
/ 27 мая 2011

попробуйте объявить

UISwitch uiSwitch;

на уровне класса.Возможно, что когда ваш метод выходит из области видимости, GC очищает вашу ссылку на uiSwitch, так что, когда делегат запускается, его ссылка больше не существует.Многие люди сталкивались с подобными проблемами, начиная с MT 4.0.

0 голосов
/ 28 мая 2011

Примечание: в своем коде вы добавляете новый переключатель UIS каждый раз, когда ячейка ИСПОЛЬЗУЕТСЯ, а не только при ее создании.Прокрутка в этом списке с несколькими десятками элементов, вероятно, будет достаточной для сбоя приложения с переполнением стека.

Чтобы исправить это, убедитесь, что вы переместили создание UISwitch внутрь оператора if ( cell == null ), поэтомучто UISwitch создается только при создании новой ячейки, а не при ее повторном использовании из кэша.

...