• Stars
    star
    3,799
  • Rank 11,595 (Top 0.3 %)
  • Language
    Objective-C
  • License
    MIT License
  • Created about 9 years ago
  • Updated over 5 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

CODING iOS 客户端源代码

Coding_iOS客户端项目介绍

编译环境:Xcode-Version 8.0 (8A218a)

让项目跑起来先

项目里用到了 CocoaPodsCarthage,如果没有安装的话,需要先自行安装。

Clone 代码后,初次执行前,需要双击运行根目录下的bootstrap脚本。这个过程涉及到下载依赖,可能会有点久,需耐心等待。

Tip:由于用到了 submodule,所以必需要把 git 仓库 clone 到本地,而不是只点击‘下载’按钮下载 zip 文件!!!

精彩项目 任务管理 项目文档 代码托管 趣味冒泡
图片1 图片2 图片3 图片4 图片5

下面介绍一下文件的大概目录先:

    .
    ├── Coding_iOS
    │   ├── Models:数据类
    │   ├── Views:视图类
    │   │   ├── CCell:所有的 CollectionViewCell 都在这里
    │   │   ├── Cell:所有的 TableViewCell 都在这里
    │   │   └── XXX:ListView(项目、动态、任务、讨论、文档、代码)和 InputView(用于聊天和评论的输入框)
    │   ├── Controllers:控制器,对应app中的各个页面
    │   │   ├── Login:登录页面
    │   │   ├── RootControllers:登录后的根页面
    │   │   ├── MeSetting:设置信息页面
    │   │   └── XXX:其它页面
    │   ├── Images:app 中用到的所有的图片都在这里
    │   ├── Resources:资源文件
    │   ├── Util:一些常用控件和 Category、Manager 之类
    │   │   ├── Common
    │   │   ├── Manager
    │   │   ├── OC_Category
    │   │   └── ObjcRuntime
    │   └── Vendor:用到的一些第三方类库,一般都有改动
    │       ├── AFNetworking
    │       ├── AGEmojiKeyboard
    │       ├── ASProgressPopUpView
    │       ├── ActionSheetPicker
    │       ├── FontAwesome+iOS
    │       ├── MJPhotoBrowser
    │       ├── MLEmojiLabel
    │       ├── NSDate+Helper
    │       ├── NSStringEmojize
    │       ├── PPiAwesomeButton
    │       ├── QBImagePickerController
    │       ├── RDVTabBarController
    │       ├── SMPageControl
    │       ├── SVPullToRefresh
    │       ├── SWTableViewCell
    │       ├── UMENG
    │       ├── UMessage_Sdk_1.1.0
    │       ├── XGPush
    │       ├── XTSegmentControl
    │       └── iCarousel
    └── Pods:项目使用了 [CocoaPods](http://code4app.com/article/cocoapods-install-usage) 这个类库管理工具

再说下项目的启动流程:

在 AppDelegate 的启动方法中,先设置了一下 Appearance 的样式,然后根据用户的登录状态选择是去加载登录页面 LoginViewController,还是登录后的 RootTabViewController 页面。

RootTabViewController 继承自第三方库 RDVTabBarController。在 RootTabViewController 里面依次加载了 Project_RootViewController、MyTask_RootViewController、Tweet_RootViewController、Message_RootViewController、Me_RootViewController 五个 RootViewController,后续的页面跳转都是基于这几个 RootViewController 引过去的。

项目里面还有些需要注意的点

  • Coding_NetAPIManager:基本上 app 的所有请求接口都放在了这里。网络请求使用的是 AFNetworking 库,与服务器之间的数据交互格式用的都是 json(与 Coding 使用的 api 一致)。

  • 关于推送:刚开始是用的 友盟推送,后来又改用了 腾讯信鸽,因为要兼顾旧版本 app 的推送,所以服务器是同时保留了两套推送。但是为了确保新版本的 app 不同时收到双份相同的推送消息,所以当前代码里还存留了友盟的 sdk,用于解除推送 token 与友盟 Alias 的绑定。

  • 关于 ProjectViewController:这个就是进入到某个项目之后的页面,这里包含了项目的动态、任务、讨论、文档、代码、成员各类信息,而且每类信息里面还可能会有新的分类(如‘任务’里面还分有各个成员的任务);这个页面相当的臃肿,我对它们做了拆分,都放在视图类 Views 目录下面。 首先是把数据列表独立成了对应的 XXXListView(如 ProjectTaskListView);然后如果需要标签切换的话,会再新建一个 XXXsView(如:ProjectTasksView),在这个视图中,上面会放一个切换栏 XTSegmentControl 显示各个标签,下面放一个 iCarousel 可以滑动显示各个标签的内容;最后这些视图都会存储在 ProjectViewController 的 projectContentDict 变量里面,根据顶部导航栏选择的类别,去显示或隐藏对应的视图。

  • 关于 UIMessageInputView:这个是私信聊天的输入框。因为这个输入框好多地方都有用到(冒泡、任务、讨论的评论还有私信),所以这个输入框就写成了一个相对独立的控件,并且直接显示在了 keyWindow 里面而不是某个视图里。这里的表情键盘用的是 AGEmojiKeyboard 改写了一下。

  • 关于 Emoji:这个,Coding 站点的 emoji 都是用的图片,而且服务器是不接受大部分 emoji 字符的,所以刚开始的时候 app 一直不能处理 emoji 表情;又因为没有 emoji 图片名和 emoji code 码的对应关系表,所以拖了很久都没能做好转换。直到在 github 上面找到了 NSStringEmojize 这个项目;试了一下,虽然也不能全部解析,但是大部分表情都能正确显示了,不能更感谢。

  • 关于如何正确显示冒泡的内容:api 返回的数据里面,冒泡内容都是 html 格式,需要做一下预处理;其实私信、讨论里面的内容也是 html。解析 html 的类名是 HtmlMediaItem,它是先用 hpple 对 html 进行了解析,然后把对应的 media 元素和对应的位置做一个存储,显示的时候便可以根据需要来显示了。

最后说下 CocoaPods 里面用到的第三方类库

License

Coding is available under the MIT license. See the LICENSE file for more info.

More Repositories

1

WebIDE

Coding WebIDE Community Edition
Shell
1,711
star
2

WebIDE-Frontend

WebIDE 前端项目
JavaScript
380
star
3

Coding-iPad

CODING iPad 客户端源代码
Objective-C
298
star
4

Coding-Android

Coding Android 客户端源代码
HTML
263
star
5

WebIDE-Backend

WebIDE 后端项目
Java
230
star
6

coding-download-center

CODING 公共制品库
Shell
52
star
7

WebIDE-Frontend-Webjars

webjar 项目,用于将 WebIDE 前端打包成 webjar
40
star
8

emoji-java

emoji-java
Java
35
star
9

coding.github.io

🌏最👍的云端开发平台 > https://coding.github.io
HTML
33
star
10

m.coding.net

https://m.coding.net 源代码
JavaScript
21
star
11

awesome-blogs

最佳 Coding Pages 博客合集
16
star
12

Comments

(Migrated) A comment system based on Coding.net
JavaScript
13
star
13

Coding-Plugin-for-JetBrains

Coding-Plugin-for-JetBrains
Java
10
star
14

Coding-Emoji

Coding 洋葱猴表情 😄 欢迎大家提交自己的个性洋葱猴表情 ^_^
HTML
7
star
15

ci-plugins

plugins for coding-ci
6
star
16

coding-cli

CODING 命令行工具,提供事项导入导出等功能
PHP
4
star
17

helm-push

用于推送 Chart 包到 Coding 制品库的 Helm 插件。
Shell
4
star
18

Webhook.v2.Demo

JavaScript
4
star
19

coding-generic

用于推送 generic 类型的制品到制品库
JavaScript
4
star
20

url2pic

A web service for fetching url and converting into image using headless Chromium.
JavaScript
3
star
21

Coding-Plus

为 Coding.net 添加更多酷炫的特性的 Chrome 插件!
CSS
3
star
22

coding-sketch-toolkit

A series of sketch scripts for CODING designers
JavaScript
2
star
23

WebIDE-CI

Java
2
star
24

coding-activeness-graph-widget

Coding 活跃图挂件
JavaScript
2
star
25

coding-sdk-php

CODING.net SDK for PHP
PHP
1
star
26

coding-design-token-vscode-snippets

1
star
27

cloudstudio-extension

The cloudstudio.d.ts node module
1
star
28

pages-builder-jekyll

Coding Pages Builder for Jekyll
Shell
1
star
29

coding-images

扣钉 Docker images,用于持续集成
Dockerfile
1
star
30

WebIDE-Plugin-Env

ENV for Coding/WebIDE
JavaScript
1
star