cocos2d-x 使用UIWebView加载网页(顺便可以看到如何用OC调C++)
猴子原创,欢迎转载。转载请注明: 转载自Cocos2D开发网–Cocos2Dev.com,谢谢!
原文地址: http://www.cocos2dev.com/?p=248
前段时间项目中要微博授权登陆,使用的是web登陆方式。所以要在cocos2d-x中显示网页。所以就将UIWebView用进来了。
实现上讲也不是很难,你开打AppController.mm,你可以看到cocos2d-x的场景是被加载在一个EAGLView上面。所以我只需要取到EAGLView,在上面加一个UIView,UIView上面就可以放我的UIWebView。
实现:FMUIWebViewBridge.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
#import <Foundation/Foundation.h> #import <CoreLocation/CoreLocation.h> #import <UIKit/UIKit.h> #import "FMLayerWebView.h" @interface FMUIWebViewBridge : NSObject<UIWebViewDelegate,UIAlertViewDelegate>{ FMLayerWebView * mLayerWebView; UIView *mView; UIWebView *mWebView; UIToolbar *mToolbar; UIBarButtonItem *mBackButton; } -( void ) setLayerWebView : (FMLayerWebView*) iLayerWebView URLString:( const char *) urlString; -( void ) backClicked:(id)sender; @end |
FMUIWebViewBridge.mm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
|
// // FMUIWebViewBridge.cpp // WebViewDemo // // Created by Yanghui Liu on 12-6-5. // Copyright (c) 2012年 FMinutes company. All rights reserved. // #import "FMUIWebViewBridge.h" #import "EAGLView.h" @implementation FMUIWebViewBridge - (id)init{ self = [super init]; if (self) { // init code here. } return self; } - ( void )dealloc{ [mBackButton release]; [mToolbar release]; [mWebView release]; [mView release]; [super dealloc]; } -( void ) setLayerWebView : (FMLayerWebView*) iLayerWebView URLString:( const char *) urlString{ mLayerWebView = iLayerWebView; cocos2d::CCSize size = mLayerWebView-> getContentSize(); mView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, size.width , size.height)]; // create webView //Bottom size int wBottomMargin = size.height*0.10; int wWebViewHeight = size.height - wBottomMargin; mWebView = [[UIWebView alloc] initWithFrame:CGRectMake(0, 0, size.width, wWebViewHeight)]; mWebView.delegate = self; NSString *urlBase = [NSString stringWithCString:urlString encoding:NSUTF8StringEncoding]; [mWebView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:urlBase ]]]; [mWebView setUserInteractionEnabled:NO]; //don't let the user scroll while things are //create a tool bar for the bottom of the screen to hold the back button mToolbar = [UIToolbar new ]; [mToolbar setFrame:CGRectMake(0, wWebViewHeight, size.width, wBottomMargin)]; mToolbar.barStyle = UIBarStyleBlackOpaque; //Create a button mBackButton = [[UIBarButtonItem alloc] initWithTitle:@ "Back" style: UIBarButtonItemStyleDone target: self action:@selector(backClicked:)]; //[backButton setBounds:CGRectMake(0.0, 0.0, 95.0, 34.0)]; [mToolbar setItems:[NSArray arrayWithObjects:mBackButton,nil] animated:YES]; [mView addSubview:mToolbar]; //[mToolbar release]; // add the webView to the view [mView addSubview:mWebView]; [[EAGLView sharedEGLView] addSubview:mView]; } - ( void )webViewDidStartLoad:(UIWebView *)thisWebView { } - ( void )webViewDidFinishLoad:(UIWebView *)thisWebView{ [mWebView setUserInteractionEnabled:YES]; mLayerWebView->webViewDidFinishLoad(); } - ( void )webView:(UIWebView *)thisWebView didFailLoadWithError:(NSError *)error { if ([error code] != -999 && error != NULL) { //error -999 happens when the user clicks on something before it's done loading. UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@ "Network Error" message:@ "Unable to load the page. Please keep network connection." delegate:self cancelButtonTitle:nil otherButtonTitles:@ "OK" , nil]; [alert show]; [alert release]; } } -( void ) backClicked:(id)sender { mWebView.delegate = nil; //keep the webview from firing off any extra messages //remove items from the Superview...just to make sure they're gone [mToolbar removeFromSuperview]; [mWebView removeFromSuperview]; [mView removeFromSuperview]; mLayerWebView->onBackbuttonClick(); } @end |
因为这些都是OC代码,所以文件后缀使用mm,为了和C++代码混编。代码很简答,应该看得懂,我就不解释了。
下面就是封装这个oc代码,
FMLayerWebView.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
// // FMLayerWebView.h // WebViewDemo // // Created by Yanghui Liu on 12-6-5. // Copyright (c) 2012年 FMinutes company. All rights reserved. // #ifndef WebViewDemo_FMLayerWebView_h #define WebViewDemo_FMLayerWebView_h #include "CCCommon.h" #include "cocos2d.h" USING_NS_CC; class FMLayerWebView : public CCLayer{ public : FMLayerWebView(); ~FMLayerWebView(); virtual bool init(); LAYER_NODE_FUNC(FMLayerWebView); void webViewDidFinishLoad(); void onBackbuttonClick(); private : int mWebViewLoadCounter; }; #endif < div ></ div > |
FMLayerWebView.mm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
// // FMLayerWebView.mm // WebViewDemo // // Created by Yanghui Liu on 12-6-5. // Copyright (c) 2012年 FMinutes company. All rights reserved. // #include "FMLayerWebView.h" #include "FMUIWebViewBridge.h" static FMUIWebViewBridge *g_FMUIWebViewBridge=nil; FMLayerWebView::FMLayerWebView(){ } FMLayerWebView::~FMLayerWebView(){ [g_FMUIWebViewBridge release]; } void FMLayerWebView::webViewDidFinishLoad(){ } void FMLayerWebView::onBackbuttonClick(){ this ->removeFromParentAndCleanup( true ); } bool FMLayerWebView::init(){ if ( !CCLayer::init() ){ return false ; } g_FMUIWebViewBridge = [[FMUIWebViewBridge alloc] init]; return true ; } |
OK ,这样就完成了。
调用方法:
1
2
3
4
5
|
FMLayerWebView* web = FMLayerWebView::node(); web->setPosition(CCPointZero); addChild(web); |
cocos2d-x 使用UIWebView加载网页(顺便可以看到如何用OC调C++)的更多相关文章
- 【iOS系列】-UIWebView加载网页禁止左右滑动
[iOS系列]-UIWebView加载网页禁止左右滑动 问题: 做项目时候,用UIWebView加载网页的时候,要求是和微信网页中打开的网页的效果一样,也即是只能上下滑动,不能左右滑动,也不能缩放. ...
- UIWebView 加载网页、文件、 html-b
UIWebView 是用来加载加载网页数据的一个框.UIWebView可以用来加载pdf word doc 等等文件 生成webview 有两种方法,1.通过storyboard 拖拽 2.通过al ...
- UIWebView 加载网页、文件、 html
UIWebView 是用来加载加载网页数据的一个框.UIWebView可以用来加载pdf word doc 等等文件 生成webview 有两种方法,1.通过storyboard 拖拽 2.通过al ...
- Swift-01 UIWebView加载网页
UIWebView在swift里面的语法,和OC不太一样,但是,使用方法什么的,都是从OC演变过来的.比如,都得有init方法,都有loadRequest方法,所以,有了OC这个基础,学习swift是 ...
- 关于iOS UIWebView 加载网页,点击网页内某些控件导致 Application 'UIKitApplication:xxx.xxx.xxx' was killed by jetsam.
问题:公司用的腾讯问卷系统,内嵌在我们应用或游戏的自定义UIWebView里面展示,发现在iOS 10 以下系统,点击圆形勾选框 会大概率出现闪退. 通过联调发现:报了这样一个警告Applicatio ...
- UIWebView各种加载网页的方式
UIWebView加载网页的方法 最近在使用UIWebView的时候遇到各种不同形式加载网页的方式,总结起来共有三种方式,分别为:使用URL加载,使用HTML源码加载,使用HTML文件加载,各种方法的 ...
- iOS之webview加载网页、文件、html的方法
UIWebView 是用来加载加载网页数据的一个框.UIWebView可以用来加载pdf.word.doc 等等文件 生成webview 有两种方法,1.通过storyboard 拖拽 2.通过a ...
- 【iOS进阶】UIWebview加载搜狐视频,自动跳回客户端 问题解决
UIWebview加载搜狐视频,自动跳回搜狐客户端 问题解决 当我们用UIWebview(iOS端)加载网页视频的时候,会发现,当真机上有搜狐客户端的时候,会自动跳转到搜狐客户端进行播放,这样的体验对 ...
- Android中Http加载如何得到Cookie和 WebView 加载网页如何得到的Cookie
最近做项目在手机端登录Http请求和 WebView 记载登录获取Cookie信息,可查看Cookie信息. 如图: Http请求获取Cookie信息: public static String re ...
随机推荐
- android中实现“再按一次退出”功能
首先,定义两次点击退出按钮的时间间隔:private static final long INTERNAL_TIME=2000; 然后,定义一个当前时间的变量:private long exitTim ...
- C#&JQuery非缓存式无刷新临时存储数据之仿购物车功能
感谢广大博问博友的帮助和共同研究讨论,终于实现了一个无缓存无刷新仿购物车的小功能: 一.实现效果简述: 有一种列表,是由双层Repeater嵌套,第一层用来显示类别,第二层用来显示类别下的商品数据, ...
- poi 导入/导出 工具类
package com.holy.util; import java.io.File; import java.io.FileOutputStream; import java.io.IOExcept ...
- iOS-scrollview及其子类适配iOS7
问题描述: 在iOS7之后如果在导航控制器中所属的字控制器中嵌入scrollview及其子类的视图,当scrollview的尺寸太小的话不会调用返回cell的方法.控制器的嵌套层级结构如下图所示,着重 ...
- c# 串口发送接收数据
/********************** 串口数据接收事件 *****************************/ private void SerialPort_DataReceived ...
- hibernate3.0 org.dom4j.DocumentException: Connection timed out: connect Nested exception:
hibernate3.0 org.dom4j.DocumentException: Connection timed out: connect Nested exception: 所报异常: 严重 ...
- 使用CPA4破解经典密码算法
下面是一段经过经典密码算法加密的密文(加密算法未知): yvvnerujjvnywhbdvkpchfgvjtzwqsuporqfzpoekkjgziicdwwkeejdsruef whwseyej ...
- jQuery 快速入门教程
内容目录 jQuery 入门 什么是jQuery 如何使用jQuery jQuery的运行原理 如何选择jQuery版本 ready() 准备就绪时执行代码 jQuery 核心:选取元素 使用jQue ...
- CSS3鼠标移入移出图片生成随机动画
今天分享使用html+css3+少量jquery实现鼠标移入移出图片生成随机动画,我们先看最终效果图(截图为静态效果,做出来可是动态的哟) 左右旋转 上下移动 缩放 由于时间关系我就不一步步解析各段代 ...
- 京东电话面试——PHP开发
1.学过<数据结构>吗?你学过的计算机相关课程有哪些? 2.web操作中,当你输入一个url到看到页面,描述一下这中间发生了什么? 3.TCP/IP的请求方式都有哪些? 4.POST和GE ...