NAMapKit 技术文档
1. 安装指南
为了开始使用 NAMapKit,你需要在你的项目中添加这个库。最简单的方式是使用 CocoaPods。在你的项目 Podfile 中添加以下代码:
pod 'NAMapKit'
然后运行 pod install 来安装 NAMapKit。
另外,你也可以通过运行以下命令来尝试 NAMapKit:
pod try NAMapKit
2. 项目使用说明
NAMapKit 允许你在标准的 UIImage 或瓦片化的 NATiledImageView 上放置大头针或自定义注释。它包括弹窗、多彩大头针、动画、缩放和手势支持。
默认注释
首先,在一个视图控制器中创建一个 NAMapView。
NAMapView *mapView = [[NAMapView alloc] initWithFrame:self.view.bounds];
mapView.backgroundColor = [UIColor colorWithRed:0.000f green:0.475f blue:0.761f alpha:1.000f];
mapView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
mapView.minimumZoomScale = 0.5f;
mapView.maximumZoomScale = 1.5f;
[mapView displayMap:[UIImage imageNamed:@"australia"]];
[self.view addSubview:mapView];
然后,添加 NADotAnnotation 注释。
NADotAnnotation *dot = [NADotAnnotation annotationWithPoint:CGPointMake(543.0f, 489.0f)];
[mapView addAnnotation:dot animated:NO];
自定义注释
你可以通过创建一个继承自 NAAnnotation 的子类来实现自定义注释,并实现 createViewOnMapView 方法来返回一个自定义注释视图。你也可以通过实现 addToMapView 方法来为注释添加自定义动画,或者通过重写 updatePosition 方法根据你的自定义逻辑来居中注释。
你可以在 NAPinAnnotation.h 和 NAPinAnnotation.m 中找到一个多色大头针的完整自定义注释示例,以及在 NAPinAnnotationsPopupMenuDemoViewController.h 和 NAPinAnnotationsPopupMenuDemoViewController.m 中的弹出菜单示例。
委托
你可以通过注册一个 mapViewDelegate 来捕获手指点击和缩放变化。委托必须实现 NAMapViewDelegate 协议。
@implementation DemoViewController
- (void)viewDidLoad
{
// 注册视图控制器为地图的委托
self.mapView.mapViewDelegate = self;
}
- (void)mapView:(NAMapView *)mapView tappedOnAnnotation:(NAPinAnnotation *)annotation
{
// 用户点击注释时调用
}
- (void)mapView:(NAMapView *)mapView hasChangedZoomLevel:(CGFloat)level
{
// 地图缩放级别变化时调用
}
@end
你可以在 NAAnnotationDemoViewController.m 中找到一个完整的示例。
瓦片地图
NAMapKit 提供了 NATiledImageMapView,支持瓦片地图。深缩放地图瓦片的典型组织方式是每个缩放级别一个文件夹,每个瓦片一个 JPG 文件。你可以在 这里看到一个示例。NAMapKit 使用 ARTiledImageView。你可以使用 dzt 或 OpenSeadragon 项目中列出的任何其他工具来生成瓦片。
你可以在 NATiledImageDemoViewController.m 中找到一个完整的瓦片地图示例。
自定义手势
NAMapKit 暴露了两个双击手势,这样你可以使用 delaysTouchesBegan 来优先处理双击而不是地图点击,或者完全用自己的手势来替换。
3. 项目 API 使用文档
NAMapKit 的 API 使用文档包括类的详细描述和它们的方法。以下是部分类的简要说明:
NAMapView: 地图视图,用于显示地图和注释。NAAnnotation: 注释的基类,用于在地图上表示自定义注释。NADotAnnotation: 默认的注释类,用于在地图上放置一个点。NATiledImageMapView: 支持瓦片地图的视图。
更多详细信息,请查看官方文档。
4. 项目安装方式
除了使用 CocoaPods,你也可以手动将 NAMapKit 的源代码添加到你的项目中。你需要:
- 下载 NAMapKit 的源代码。
- 将源代码添加到你的 Xcode 项目中。
- 确保你的项目设置链接到必要的框架,例如 Foundation 和 UIKit。
以上是 NAMapKit 的技术文档,希望对你有所帮助。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00