如何在用户到达某个位置时触发视频?

发布于 2024-11-28 10:45:45 字数 6936 浏览 2 评论 0原文

这是我的 CoreLocationController.h 目标 c class

#import <Foundation/Foundation.h>
#import <CoreLocation/CoreLocation.h>
#import <MapKit/MapKit.h>

extern const CLLocationAccuracy kCLLocationAccuracyBest;
@protocol CoreLocationControllerDelegate 
@required
- (BOOL)startRegionMonitoring;
- (void)locationUpdate:(CLLocation *)location; // Our location updates are sent here
- (void)locationError:(NSError *)error; // Any errors are sent here
@end

@interface CoreLocationController : NSObject <CLLocationManagerDelegate, MKMapViewDelegate>      {
CLLocationManager *locMgr;
CLLocationCoordinate2D coordinate;
IBOutlet MKMapView *worldView;
IBOutlet UIActivityIndicatorView *activityIndicator;
id delegate;
} 

@property (nonatomic, retain) CLLocationManager *locMgr;
@property (nonatomic, assign) id delegate;
@property (nonatomic, readonly) CLLocationCoordinate2D coordinate;

@end

这是 CorelocationController.m

#import "CoreLocationController.h"


@implementation CoreLocationController
@synthesize locMgr, delegate, coordinate;

- (id)init {
    self = [super init];

    if(self != nil) {
        self.locMgr = [[[CLLocationManager alloc] init] autorelease]; // Create new instance of locMgr
        self.locMgr.delegate = self; // Set the delegate as self.

        [locMgr setDistanceFilter:kCLDistanceFilterNone];
        [locMgr setDesiredAccuracy:kCLLocationAccuracyBest];

        [worldView setShowsUserLocation:YES];
    }

    return self;
}

- (BOOL)startRegionMonitoring {

    if (![CLLocationManager regionMonitoringAvailable] || ![CLLocationManager regionMonitoringEnabled] )
        return NO;
    CLLocationCoordinate2D home;
    home.latitude = +51.49410630;
    home.longitude = -0.10251360;

    CLRegion * region = [[CLRegion alloc] initCircularRegionWithCenter:home radius:10.0 identifier:@"home"];
    if (locMgr == nil)
        locMgr = ([[CLLocationManager alloc] init]);
    [locMgr startMonitoringForRegion:region desiredAccuracy:kCLLocationAccuracyBest];

    [region release];
    return YES;
}

- (void)locationManager:(CLLocationManager *)manager didEnterRegion:(CLRegion *)region{
    NSLog(@"Enteed location");
//  [self leavingHomeNotify];
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"Location entered" message:@"Region entered" delegate:NULL cancelButtonTitle:@"OK" otherButtonTitles:NULL];
    [alert show];
}

- (void)locationManager:(CLLocationManager *)manager didUpdateToLocation:(CLLocation *)newLocation fromLocation:(CLLocation *)oldLocation {
    if([self.delegate conformsToProtocol:@protocol(CoreLocationControllerDelegate)]) {  // Check if the class assigning itself as the delegate conforms to our protocol.  If not, the message will go nowhere.  Not good.
        [self.delegate locationUpdate:newLocation];

    }
}

- (void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error {
    if([self.delegate conformsToProtocol:@protocol(CoreLocationControllerDelegate)]) {     // Check if the class assigning itself as the delegate conforms to our protocol.  If not, the message will go nowhere.  Not good.
        [self.delegate locationError:error];
    }
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"Location failed" message:@"Location failed" delegate:NULL cancelButtonTitle:@"OK" otherButtonTitles:NULL];
    [alert show];
}
     - (void)dealloc {
    [self.locMgr release];
    [super dealloc];
}


@end

这是 CoreLocationDemoViewer.h

#import <UIKit/UIKit.h>
#import "CoreLocationController.h"
#import <MapKit/MapKit.h>

@interface CoreLocationDemoViewController : UIViewController <CoreLocationControllerDelegate, MKMapViewDelegate> {
    CoreLocationController *CLController;
    IBOutlet UILabel *locLabel;
    MKMapView *worldView;

}

@property (nonatomic, retain) CoreLocationController *CLController;
@property (nonatomic, retain) IBOutlet UILabel *locLabel;
@property (nonatomic, retain) MKMapView *worldView;

@end

这是 CoreLocationDemoViewer.m

#import "CoreLocationDemoViewController.h"


@implementation CoreLocationDemoViewController
@synthesize CLController;
@synthesize locLabel;
@synthesize worldView;


- (void)viewDidLoad {
    [super viewDidLoad];
    self.worldView.mapType = MKMapTypeStandard;   // also MKMapTypeSatellite or MKMapTypeHybrid
    CLController = [[CoreLocationController alloc] init];
    CLController.delegate = self;
    [CLController.locMgr startUpdatingLocation];


    worldView.zoomEnabled = YES;
    worldView.scrollEnabled = YES;


}
- (void)mapView:(MKMapView *)mapView didUpdateUserLocation:(MKUserLocation *)u
{
    CLLocationCoordinate2D loc = [u coordinate];
    MKCoordinateRegion region = MKCoordinateRegionMakeWithDistance(loc, 250, 250);
    [worldView setRegion:region animated:YES];
}



- (void)locationUpdate:(CLLocation *)location {
    locLabel.text = [location description];
//  [mapView setCenterCoordinate:location.coordinate];
//  [mapView setShowsUserLocation:YES];

    CLLocationCoordinate2D coord = [location coordinate];

    // Add it to the map view
//    [worldView addAnnotation:mp];

    // MKMapView retains its annotations, we can release
//  [mp release];

    // Zoom the region to this location
    MKCoordinateRegion region = MKCoordinateRegionMakeWithDistance(coord, 50, 50);
    [worldView setRegion:region animated:YES];

//   [locationManager stopUpdatingLocation];    
}

- (void)locationError:(NSError *)error {
    locLabel.text = [error description];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
}

// The designated initializer.  Override if you create the controller programmatically and want to perform customization that is not appropriate for viewDidLoad.
/*
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
    if (self) {
        // Custom initialization.
    }
    return self;
}
*/

/*
// Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
- (void)viewDidLoad {
    [super viewDidLoad];
}
*/

/*
// Override to allow orientations other than the default portrait orientation.
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
    // Return YES for supported orientations.
    return (interfaceOrientation == UIInterfaceOrientationPortrait);
}
*/



- (void)viewDidUnload {
    [super viewDidUnload];
     self.worldView = nil;

    // Release any retained subviews of the main view.
    // e.g. self.myOutlet = nil;
}


- (void)dealloc {
    [CLController release];
    [worldView release];
    [super dealloc];
}

@end

好的,这就是我想要的。到目前为止,它显示的是带有用户位置的地图 它找到标签上显示的确切位置..如果我做错了什么,正确的..

我想做的是当用户到达某个位置时触发视频...

我正在接近正确的位置吗?

This is my CoreLocationController.h objective c class

#import <Foundation/Foundation.h>
#import <CoreLocation/CoreLocation.h>
#import <MapKit/MapKit.h>

extern const CLLocationAccuracy kCLLocationAccuracyBest;
@protocol CoreLocationControllerDelegate 
@required
- (BOOL)startRegionMonitoring;
- (void)locationUpdate:(CLLocation *)location; // Our location updates are sent here
- (void)locationError:(NSError *)error; // Any errors are sent here
@end

@interface CoreLocationController : NSObject <CLLocationManagerDelegate, MKMapViewDelegate>      {
CLLocationManager *locMgr;
CLLocationCoordinate2D coordinate;
IBOutlet MKMapView *worldView;
IBOutlet UIActivityIndicatorView *activityIndicator;
id delegate;
} 

@property (nonatomic, retain) CLLocationManager *locMgr;
@property (nonatomic, assign) id delegate;
@property (nonatomic, readonly) CLLocationCoordinate2D coordinate;

@end

and this is the CorelocationController.m

#import "CoreLocationController.h"


@implementation CoreLocationController
@synthesize locMgr, delegate, coordinate;

- (id)init {
    self = [super init];

    if(self != nil) {
        self.locMgr = [[[CLLocationManager alloc] init] autorelease]; // Create new instance of locMgr
        self.locMgr.delegate = self; // Set the delegate as self.

        [locMgr setDistanceFilter:kCLDistanceFilterNone];
        [locMgr setDesiredAccuracy:kCLLocationAccuracyBest];

        [worldView setShowsUserLocation:YES];
    }

    return self;
}

- (BOOL)startRegionMonitoring {

    if (![CLLocationManager regionMonitoringAvailable] || ![CLLocationManager regionMonitoringEnabled] )
        return NO;
    CLLocationCoordinate2D home;
    home.latitude = +51.49410630;
    home.longitude = -0.10251360;

    CLRegion * region = [[CLRegion alloc] initCircularRegionWithCenter:home radius:10.0 identifier:@"home"];
    if (locMgr == nil)
        locMgr = ([[CLLocationManager alloc] init]);
    [locMgr startMonitoringForRegion:region desiredAccuracy:kCLLocationAccuracyBest];

    [region release];
    return YES;
}

- (void)locationManager:(CLLocationManager *)manager didEnterRegion:(CLRegion *)region{
    NSLog(@"Enteed location");
//  [self leavingHomeNotify];
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"Location entered" message:@"Region entered" delegate:NULL cancelButtonTitle:@"OK" otherButtonTitles:NULL];
    [alert show];
}

- (void)locationManager:(CLLocationManager *)manager didUpdateToLocation:(CLLocation *)newLocation fromLocation:(CLLocation *)oldLocation {
    if([self.delegate conformsToProtocol:@protocol(CoreLocationControllerDelegate)]) {  // Check if the class assigning itself as the delegate conforms to our protocol.  If not, the message will go nowhere.  Not good.
        [self.delegate locationUpdate:newLocation];

    }
}

- (void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error {
    if([self.delegate conformsToProtocol:@protocol(CoreLocationControllerDelegate)]) {     // Check if the class assigning itself as the delegate conforms to our protocol.  If not, the message will go nowhere.  Not good.
        [self.delegate locationError:error];
    }
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"Location failed" message:@"Location failed" delegate:NULL cancelButtonTitle:@"OK" otherButtonTitles:NULL];
    [alert show];
}
     - (void)dealloc {
    [self.locMgr release];
    [super dealloc];
}


@end

This is the CoreLocationDemoViewer.h

#import <UIKit/UIKit.h>
#import "CoreLocationController.h"
#import <MapKit/MapKit.h>

@interface CoreLocationDemoViewController : UIViewController <CoreLocationControllerDelegate, MKMapViewDelegate> {
    CoreLocationController *CLController;
    IBOutlet UILabel *locLabel;
    MKMapView *worldView;

}

@property (nonatomic, retain) CoreLocationController *CLController;
@property (nonatomic, retain) IBOutlet UILabel *locLabel;
@property (nonatomic, retain) MKMapView *worldView;

@end

This is the CoreLocationDemoViewer.m

#import "CoreLocationDemoViewController.h"


@implementation CoreLocationDemoViewController
@synthesize CLController;
@synthesize locLabel;
@synthesize worldView;


- (void)viewDidLoad {
    [super viewDidLoad];
    self.worldView.mapType = MKMapTypeStandard;   // also MKMapTypeSatellite or MKMapTypeHybrid
    CLController = [[CoreLocationController alloc] init];
    CLController.delegate = self;
    [CLController.locMgr startUpdatingLocation];


    worldView.zoomEnabled = YES;
    worldView.scrollEnabled = YES;


}
- (void)mapView:(MKMapView *)mapView didUpdateUserLocation:(MKUserLocation *)u
{
    CLLocationCoordinate2D loc = [u coordinate];
    MKCoordinateRegion region = MKCoordinateRegionMakeWithDistance(loc, 250, 250);
    [worldView setRegion:region animated:YES];
}



- (void)locationUpdate:(CLLocation *)location {
    locLabel.text = [location description];
//  [mapView setCenterCoordinate:location.coordinate];
//  [mapView setShowsUserLocation:YES];

    CLLocationCoordinate2D coord = [location coordinate];

    // Add it to the map view
//    [worldView addAnnotation:mp];

    // MKMapView retains its annotations, we can release
//  [mp release];

    // Zoom the region to this location
    MKCoordinateRegion region = MKCoordinateRegionMakeWithDistance(coord, 50, 50);
    [worldView setRegion:region animated:YES];

//   [locationManager stopUpdatingLocation];    
}

- (void)locationError:(NSError *)error {
    locLabel.text = [error description];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
}

// The designated initializer.  Override if you create the controller programmatically and want to perform customization that is not appropriate for viewDidLoad.
/*
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
    if (self) {
        // Custom initialization.
    }
    return self;
}
*/

/*
// Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
- (void)viewDidLoad {
    [super viewDidLoad];
}
*/

/*
// Override to allow orientations other than the default portrait orientation.
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
    // Return YES for supported orientations.
    return (interfaceOrientation == UIInterfaceOrientationPortrait);
}
*/



- (void)viewDidUnload {
    [super viewDidUnload];
     self.worldView = nil;

    // Release any retained subviews of the main view.
    // e.g. self.myOutlet = nil;
}


- (void)dealloc {
    [CLController release];
    [worldView release];
    [super dealloc];
}

@end

Ok so this is what i want. Until now it shows a map with the user location
and it finds the exact location which is shown on a label.. correct if i am doing anything wrong..

What i want to do is trigger a video when a user reaches a certain location...

IAm approaching right?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

风向决定发型 2024-12-05 10:45:45

我认为如果您只是无法正确缩放地图视图,请使用这篇文章中的 MKCooperative 内容,如何缩放 MKMapView

我正在开发一个地图视图,该视图可以缩放到合适的查看级别,并且我正在为地图设置 lattitudeDelta 和 longitudeDelta 。对我来说效果很好。

I think if you are just having trouble getting the mapView to zoom correctly, use the MKCoordinate stuff from this post, How do I zoom an MKMapView.

I am working on a mapview as well that zooms to a decent level for viewing, and I am setting the lattitudeDelta and longitudeDelta for the map. Works good for me.

挽容 2024-12-05 10:45:45

也许设置委托有问题?我通常在 .h 文件中指定委托,如下所示:

id <CoreLocationControllerDelegate> delegate;

@property (nonatomic, assign) id <CoreLocationControllerDelegate> delegate;

编辑

另外,您是否检查过 -mapView:didUpdateUserLocation: 正在被调用?

Perhaps something is wrong with setting the delegate? I usually specify the delegate in the .h file like this:

id <CoreLocationControllerDelegate> delegate;

and

@property (nonatomic, assign) id <CoreLocationControllerDelegate> delegate;

EDIT

Also, did you check that -mapView:didUpdateUserLocation: is being called?

暮年慕年 2024-12-05 10:45:45

我没有看到您为世界视图分配委托(但您为其他东西分配委托)。尝试在 viewDidLoad 中添加 worldView.delegate = self;

I don't see you assigning the delegate for worldView (but you do for your other stuff). Try adding worldView.delegate = self; in your viewDidLoad.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文