AVPlayer UITapGestureRecognizer not working

删除回忆录丶 提交于 2019-11-28 03:25:09

问题


I have this code for my AVPlayerViewController.

UITapGestureRecognizer *tap=[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapAvPlayer)];
[self.avPlayerViewController.view addGestureRecognizer:tap];

but this is not working.. :S, I tried setting

[self.avPlayerViewController.view setUserInteractionEnabled:YES];

still no good..

The only working solution is to use UIGestureRecognizer and implement it's shouldReceiveTouch delegate and check if the av player is touched.. but the issue is, we wan't to capture the "tap release" event.. because if the av player view is just touched, it immediately executes the code and that is not what we wanted...

Please help us with this issue..

Thanks!


回答1:


Or you can subclass the AVPlayerViewController and use folowwing method to

get the control : -

1.touchBegan 2.touchEnd

Make sure that you set this flag self.avPlayerContr.showsPlaybackControls = false

Hope this works for you.




回答2:


The correct place for gesture handling on an AVPlayerViewController is inside the controller's contentOverlayView .

contentOverlayView is a read-only property of AVPlayerViewController. It's a view that shows up over the video, but under the controller. Just the perfect place for touch handling. You can add subviews or gesture handlers to it at load time.

The following code gives your video controller touch support in two ways, to demonstrate both the gesture recognize and UIButton approaches.

- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender
{
    if ([segue.identifier isEqualToString:@"mySegue"])
    {
        // Set things up when we're about to go the the video
        AVPlayerViewController *avpvc = segue.destinationViewController;
        AVPlayer *p = nil;
        p = [AVPlayer playerWithURL:[NSURL URLWithString:@"https://my-video"]];
        avpvc.player = p;

        // Method 1: Add a gesture recognizer to the view
        UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(myAction:)];
        avpvc.contentOverlayView.gestureRecognizers = @[tap];

        // Method 2: Add a button to the view
        UIButton *cov = [UIButton buttonWithType:UIButtonTypeCustom];
        [cov addTarget:self action:@selector(myAction:) forControlEvents:UIControlEventTouchUpInside];
        cov.frame = self.view.bounds;
    }
}

(not really up for writing a Swift version at the moment, sorry. :)




回答3:


This should do it. Add the recognizer to the subview of the player instead:

[videoPlayerViewController.view.subviews[0] addGestureRecognizer:tap]

This was a quick fix for complex UI and gestures look into contentOverlayView see TyR answer




回答4:


As far as my knowledge is concerned what you really want to is

UILongPressGestureRecognizer

Because,

UITapGestureRecognizer

Does not have any release type of event, if u add the

UILongPressGestureRecognizer

to your

avPlayerViewController

Then in

-(BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer {
  if ( [gestureRecognizer isKindOfClass:[UILongPressGestureRecognizer class]] ) {

  }
  return YES;
}

Then you can set the minimum duration of the gesture to have a better feel,

[holdGesture setMinimumPressDuration:0.01]

Then you can implement the method,

- (void)holdAction:(UILongPressGestureRecognizer *)holdRecognizer

Then check the state of the recognizer and perform desired functionality




回答5:


You can add transparent view on avplayerViewController and can add tapgesturerecognizer on that view. hope this will help :)




回答6:


The easy solution is add a gesture view on the same movie holder view after adding the movie player. No need to add the gesture recognizer directly to the movie player.

  [self.movieHolderView addSubview:self.moviePlayer.view];


  [self.movieHolderView addSubview:self.gestureView];
  [self.movieHolderView bringSubviewToFront:self.gestureView];

Now we can add our Gesture recognizer on the gesture view like this

self.fullScreenTapGesture = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapHandler:)];
self.fullScreenTapGesture.numberOfTapsRequired = 1;
[self.gestureView addGestureRecognizer:self.fullScreenTapGesture];



回答7:


Gesture recognizer should be added differently for OS 11 and earlier OS:

Universal solution (Swift 4):

let tap = UITapGestureRecognizer(target: self, action: #selector(videoTap))
        if #available(iOS 11.0, *) {
            playerVC?.contentOverlayView?.gestureRecognizers = [tap]
        } else {
            playerVC?.view.subviews.first?.addGestureRecognizer(tap)
        }

@objc func videoTap(_ button: UIButton) {
        print("Tapped on video")
    }



回答8:


Swift 4

Add a gesture recognizer to AVPlayerViewController's view:

func playVideo() {
    let playerController = AVPlayerViewController()
    playerController.player = AVPlayer(url: URL(fileURLWithPath: videoPath))
    playerController.showsPlaybackControls = false
    playerController.view.isUserInteractionEnabled = true

    let swipeUp = UISwipeGestureRecognizer(target: self, action: #selector(self.respondToSwipeGesture))
    swipeUp.direction = UISwipeGestureRecognizerDirection.up
    playerController.view.addGestureRecognizer(swipeUp)

    present(playerController, animated: false) {
        playerController.player?.play()
    }
}

@objc func respondToSwipeGesture(gesture: UIGestureRecognizer) {
    print("swipe up")
}


来源:https://stackoverflow.com/questions/36878609/avplayer-uitapgesturerecognizer-not-working

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!