簡體   English   中英

如何使用動畫更改NSTableColumn寬度

[英]How to Change NSTableColumn width with Animation

我有一個NSScrollView和一個帶有一些NSTableColumn的NSTableView。 當我按下按鈕時,我用動畫更改了NSScrollView的寬度。 這是我的代碼:

NSDictionary *myScrollViewDictionary = [[NSDictionary alloc] initWithObjectsAndKeys:
                                               myScrollView,NSViewAnimationTargetKey,
                                               [NSValue valueWithRect:myScrollViewStartFrame],NSViewAnimationStartFrameKey,
                                               [NSValue valueWithRect:myScrollViewEndFrame],NSViewAnimationEndFrameKey, nil];

    NSViewAnimation *animation = [[NSViewAnimation alloc] initWithViewAnimations:@[myScrollViewDictionary]];
    animation.delegate = self;
    animation.duration = 0.2;
    [animation setAnimationBlockingMode:NSAnimationBlocking];
    [animation startAnimation];

這很好。

但是我想同時用相同的Animation改變每列的寬度,問題是NSTableColumn不是NSView,所以我不能改變它的框架。現在我只能在沒有任何Animation的情況下改變Column的寬度。

有人有主意嗎?

恐怕您可能必須創建自己的自定義動畫,以手動完成所有操作。 要為該列設置動畫,這是一個基本思路:

- (IBAction)animateColumn:(id)sender
{
  NSTableColumn *tableColumn; // = set your table column
  CGFloat initialWidth = [tableColumn width];
  CGFloat finalWidth; // = whatever

  dispatch_async(dispatch_get_global_queue(0,0), {
    double animationTime = 2; //seconds
    double timeElapsed = 0; //approximate measure; probably good enough

    while (timeElapsed<animationTime)
    {
      double t = timeElapsed/animationTime;

      CGFloat width = t*finalWidth + (1-t)*initialWidth;
      dispatch_async(dispatch_get_main_queue(), ^{
        [tableColumn setWidth:width];
      });

      NSDate *future = [NSDate dateWithTimeIntervalSinceNow:0.02];
      [NSThread sleepUntilDate:future];
      timeElapsed += 0.02;
    }

    dispatch_async(dispatch_get_main_queue(), ^{
      [tableColumn setWidth:finalWidth];
    });
  });
}

我想您可以根據自己的需要進行調整。 也許您可以在啟動另一個動畫的同時啟動該動畫(在兩者中使用相同的時間,在我的示例中將2更改為0.2)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM