ckplayer.js 56 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475
  1. /*
  2. -------------------------------------------------------------------------
  3. 说明:
  4. 正式使用时可以把该文件的注释全部去掉,节省加载时间
  5. ckplayer6.8,有问题请访问http://www.ckplayer.com
  6. 请注意,该文件为UTF-8编码,不需要改变编码即可使用于各种编码形式的网站内
  7. -------------------------------------------------------------------------
  8. 第一部分,加载插件
  9. 以下为加载的插件部份
  10. 插件的设置参数说明:
  11. 1、插件名称
  12. 2、水平对齐方式(0左,1中,2右)
  13. 3、垂直对齐方式(0上,1中,2下)
  14. 4、水平方向位置偏移量
  15. 5、垂直方向位置偏移量
  16. 6、插件的等级,0=普通图片插件且跟随控制栏隐藏而隐藏,显示而显示,1=普通图片插件且永久显示,2=swf插件,默认显示,3=swf插件,默认隐藏,swf插件都可以交互
  17. 7、插件是否绑定在控制栏上,0不绑定,1绑定,当值是1的时候该插件将会随着控制栏一起隐藏或缓动
  18. 8、插件为swf并且可交互时,默认调用的类所在的包名称,详细说明可以到帮助手册里查看,默认无
  19. 插件名称不能相同,对此的详细说明请到网站查看
  20. */
  21. function ckcpt() {
  22. var cpt = '';
  23. return cpt;
  24. }
  25. /*
  26. 插件的定义结束
  27. 以下是对播放器功能进行配置
  28. */
  29. function ckstyle() { //定义总的风格
  30. var ck = {
  31. cpath: '',
  32. /*
  33. 播放器风格压缩包文件的路径,默认的是style.swf
  34. 如果调用不出来可以试着设置成绝对路径试试
  35. 如果不知道路径并且使用的是默认配置,可以直接留空,播放器会
  36. */
  37. language: '',
  38. /*播放器所使用的语言配置文件,需要和播放器在同目录下,默认是language.xml*/
  39. flashvars: '',
  40. /*
  41. 这里是用来做为对flashvars值的补充,除了c和x二个参数以外的设置都可以在这里进行配置
  42. 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 3 3 3 3 3 3 3 3 3 3 4 4 4 4
  43. 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3*/
  44. setup: '1,1,1,1,1,2,0,1,0,0,0,1,200,0,2,1,0,1,1,1,1,10,3,0,1,2,3000,0,0,2,0,1,1,1,1,1,1,250,0,90,0,0,0',
  45. /*
  46. 这是配置文件里比较重要的一个参数,共有N个功能控制参数,并且以后会继续的增加,各控制参数以英文逗号(,)隔开。下面列出各参数的说明:
  47. 1、鼠标经过按钮是否使用手型,0普通鼠标,1手型鼠标,2是只有按钮手型,3是控制栏手型
  48. 2、是否支持单击暂停,0不支持,1是支持
  49. 3、是否支持双击全屏,0不支持,1是支持
  50. 4、在播放前置广告时是否同时加载视频,0不加载,1加载
  51. 5、广告显示的参考对象,0是参考视频区域,1是参考播放器区域
  52. 6、广告大小的调整方式,只针对swf和图片有效,视频是自动缩放的
  53. 0=自动调整大小,意思是说大的话就变小,小的话就变大
  54. 1=是大的化变小,小的话不变
  55. 2=是什么也不变,就这么大
  56. 3=是跟参考对像(第5个控制)参数设置的一样宽高
  57. 7、前置广告播放顺序,0是顺序播放,1是随机播放,>1则随机取所有广告中的(N-1)个进行播放
  58. 8、对于视频广告是否采用修正,0是不使用,1是使用,如果是1,则用户在网速慢的情况下会按设定的倒计时进行播放广告,计时结束则放正片(比较人性化),设置成0的话,则强制播放完广告才能播放正片
  59. 9、是否开启滚动文字广告,0是不开启,1是开启且不使用关闭按钮,2是开启并且使用关闭按钮,开启后将在加载视频的时候加载滚动文字广告
  60. 10、视频的调整方式
  61. 0=是自动调整大小,意思是说大的话就变小,小的话就变大,同时保持长宽比例不变
  62. 1=是大的化变小,小的话不变
  63. 2=是什么也不变,就这么大
  64. 3=是跟参考对像(pm_video的设置)参数设置的一样宽高
  65. 11、是否在多视频时分段加载,0不是,1是
  66. 12、缩放视频时是否进行平滑处理,0不是,1是
  67. 13、视频缓冲时间,单位:毫秒,建议不超过300
  68. 14、初始图片调整方式(
  69. 0=是自动调整大小,意思是说大的话就变小,小的话就变大,同时保持长宽比例不变
  70. 1=是大的化变小,小的话不变
  71. 2=是什么也不变,就这么大
  72. 3=是跟pm_video参数设置的一样宽高
  73. 15、暂停广告调整方式(
  74. 0=是自动调整大小,意思是说大的话就变小,小的话就变大,同时保持长宽比例不变
  75. 1=是大的化变小,小的话不变
  76. 2=是什么也不变,就这么大
  77. 3=是跟pm_video参数设置的一样宽
  78. 16、暂停广告是否使用关闭广告设置,0不使用,1使用
  79. 17、缓冲时是否播放广告,0是不显示,1是显示并同时隐藏掉缓冲图标和进度,2是显示并不隐藏缓冲图标
  80. 18、是否支持键盘空格键控制播放和暂停0不支持,1支持
  81. 19、是否支持键盘左右方向键控制快进快退0不支持,1支持
  82. 20、是否支持键盘上下方向键控制音量0不支持,1支持
  83. 21、播放器返回js全部监听函数的等级,0-2,等级越高,返回的参数越多
  84. 0=不返回全部监听事件
  85. 1=返回监听,但不在控制台输出
  86. 2=返回监听,并且在控制台同步输出
  87. 3=返回全部监听事件,并且在参数前加上"播放器ID->",用于多播放器的监听
  88. 22、快进和快退的秒数
  89. 23、界面上图片元素加载失败重新加载次数
  90. 24、开启加载皮肤压缩文件包的加载进度提示
  91. 25、使用隐藏控制栏时显示简单进度条的功能,0是不使用,1是使用,2是只在普通状态下使用
  92. 26、控制栏隐藏设置(0不隐藏,1全屏时隐藏,2都隐藏
  93. 27、控制栏隐藏延时时间,即在鼠标离开控制栏后多少毫秒后隐藏控制栏
  94. 28、滚动文字广告左右滚动时是否采用无缝,默认0采用,1是不采用
  95. 29、0是正常状态,1是控制栏默认隐藏,播放状态下鼠标经过播放器显示控制栏,2是一直隐藏控制栏
  96. 30、在播放rtmp视频时暂停后点击播放是否采用重新链接的方式,这里一共分0-2三个等级
  97. 31、当采用网址形式(flashvars里s=1/2时)读取视频地址时是采用默认0=get方法,1=post方式
  98. 32、是否启用播放按钮和暂停按钮
  99. 33、是否启用中间暂停按钮
  100. 34、是否启用静音按钮
  101. 35、是否启用全屏按钮
  102. 36、是否启用进度调节栏,0不启用,1是启用,2是只能前进(向右拖动),3是只能后退,4是只能前进但能回到第一次拖动时的位置,5是看过的地方可以随意拖动,
  103. 37、是否启用调节音量
  104. 38、计算时间的间隔,毫秒
  105. 39、前置logo至少显示的时间,单位:毫秒
  106. 40、前置视频广告的默认音量
  107. 41、当s=3/4时加载插件是否从压缩包里加载,0不是,1是
  108. 42、加载风格是否采用加密方式传送,该功能普通用户不能使用
  109. 43、在s=1/2时,调用地址里的地址是否是相对地址(相对于调用文件),0不是,1是
  110. */
  111. pm_bg: '0x000000,100,230,180',
  112. /*播放器整体的背景配置,请注意,这里只是一个初始化的设置,如果需要真正的改动播放器的背景和最小宽高,需要在风格文件里找到相同的参数进行更改。
  113. 1、整体背景颜色
  114. 2、背景透明度
  115. 3、播放器最小宽度
  116. 4、播放器最小高度
  117. 这里只是初始化时的设置,最终加载完播放器后显示的效果需要在style.swf/style.xml里设置该参数
  118. */
  119. mylogo: 'null',
  120. /*
  121. 视频加载前显示的logo文件,不使用设置成null,即mylogo='null';
  122. */
  123. pm_mylogo: '1,1,-100,-55',
  124. /*
  125. 视频加载前显示的logo文件(mylogo参数的)的位置
  126. 本软件所有的四个参数控制位置的方式全部都是统一的意思,如下
  127. 1、水平对齐方式,0是左,1是中,2是右
  128. 2、垂直对齐方式,0是上,1是中,2是下
  129. 3、水平偏移量,举例说明,如果第1个参数设置成0左对齐,第3个偏移量设置成10,就是离左边10个像素,第一个参数设置成2,偏移量如果设置的是正值就会移到播放器外面,只有设置成负值才行,设置成-1,按钮就会跑到播放器外面
  130. 4、垂直偏移量
  131. */
  132. logo: null, //'cklogo.png',
  133. /*
  134. 默认右上角一直显示的logo,不使用设置成null,即logo='null';
  135. */
  136. pm_logo: '2,0,-100,20',
  137. /*
  138. 播放器右上角的logo的位置
  139. 1、水平对齐方式,0是左,1是中,2是右
  140. 2、垂直对齐方式,0是上,1是中,2是下
  141. 3、水平偏移量
  142. 4、垂直偏移量
  143. 以下是播放器自带的二个插件
  144. */
  145. control_rel: 'related.swf,ckplayer/related.xml,0',
  146. /*
  147. 视频结束显示精彩视频的插件
  148. 1、视频播放结束后显示相关精彩视频的插件文件(注意,视频结束动作设置成3时(即var flashvars={e:3})有效),
  149. 2、xml文件是调用精彩视频的示例文件,可以自定义文件类型(比如asp,php,jsp,.net只要输出的是xml格式就行),实际使用中一定要注意第二个参数的路径要正确
  150. 3、第三个参数是设置配置文件的编码,0是默认的utf-8,1是gbk2312
  151. */
  152. control_pv: 'Preview.swf,105,2000',
  153. /*
  154. 视频预览插件
  155. 1、插件文件名称(该插件和上面的精彩视频的插件都是放在风格压缩包里的)
  156. 2、离进度栏的高(指的是插件的顶部离进度栏的位置)
  157. 3、延迟时间(该处设置鼠标经过进度栏停顿多少毫秒后才显示插件)
  158. 建议一定要设置延时时间,不然当鼠标在进度栏上划过的时候就会读取视频地址进行预览,很占资源
  159. */
  160. pm_repc: '',
  161. /*
  162. 视频地址替换符,该功能主要是用来做简单加密的功能,使用方法很简单,请注意,只针对f值是视频地址的时候有效,其它地方不能使用。具体的请查看http://www.ckplayer.com/manual.php?id=4#title_25
  163. */
  164. pm_spac: '|',
  165. /*
  166. 视频地址间隔符,这里主要是播放多段视频时使用普通调用方式或网址调用方式时使用的。默认使用|,如果视频地址里本身存在|的话需要另外设置一个间隔符,注意,即使只有一个视频也需要设置。另外在使用rtmp协议播放视频的时候,如果视频存在多级目录的话,这里要改成其它的符号,因为rtmp协议的视频地址多级的话也需要用到|隔开流地址和实例地址
  167. */
  168. pm_fpac: 'file->f',
  169. /*
  170. 该参数的功能是把自定义的flashvars里的变量替换成ckplayer里对应的变量,默认的参数的意思是把flashvars里的file值替换成f值,因为ckplayer里只认f值,多个替换之间用竖线隔开
  171. */
  172. pm_advtime: '2,0,-110,10,0,300,0',
  173. /*
  174. 前置广告倒计时文本位置,播放前置 广告时有个倒计时的显示文本框,这里是设置该文本框的位置和宽高,对齐方式的。一共7个参数,分别表示:
  175. 1、水平对齐方式,0是左对齐,1是中间对齐,2是右对齐
  176. 2、垂直对齐方式,0是上对齐,1是中间对齐,2是低部对齐
  177. 3、水平位置偏移量
  178. 4、垂直位置偏移量
  179. 5、文字对齐方式,0是左对齐,1是中间对齐,2是右对齐,3是默认对齐
  180. 6、文本框宽席
  181. 7、文本框高度
  182. */
  183. pm_advstatus: '1,2,2,-200,-40',
  184. /*
  185. 前置广告静音按钮,静音按钮只在是视频广告时显示,当然也可以控制不显示
  186. 1、是否显示0不显示,1显示
  187. 2、水平对齐方式
  188. 3、垂直对齐方式
  189. 4、水平偏移量
  190. 5、垂直偏移量
  191. */
  192. pm_advjp: '1,1,2,2,-100,-40',
  193. /*
  194. 前置广告跳过广告按钮的位置
  195. 1、是否显示0不显示,1是显示
  196. 2、跳过按钮触发对象(值0/1,0是直接跳转,1是触发js:function ckadjump(){})
  197. 3、水平对齐方式
  198. 4、垂直对齐方式
  199. 5、水平偏移量
  200. 6、垂直偏移量
  201. */
  202. pm_padvc: '2,0,-13,-13',
  203. /*
  204. 暂停广告的关闭按钮的位置
  205. 1、水平对齐方式
  206. 2、垂直对齐方式
  207. 3、水平偏移量
  208. 4、垂直偏移量
  209. */
  210. pm_advms: '2,2,-46,-67',
  211. /*
  212. 滚动广告关闭按钮位置
  213. 1、水平对齐方式
  214. 2、垂直对齐方式
  215. 3、水平偏移量
  216. 4、垂直偏移量
  217. */
  218. pm_zip: '1,1,-20,-8,1,0,0',
  219. /*
  220. 加载皮肤压缩包时提示文字的位置
  221. 1、水平对齐方式,0是左对齐,1是中间对齐,2是右对齐
  222. 2、垂直对齐方式,0是上对齐,1是中间对齐,2是低部对齐
  223. 3、水平位置偏移量
  224. 4、垂直位置偏移量
  225. 5、文字对齐方式,0是左对齐,1是中间对齐,2是右对齐,3是默认对齐
  226. 6、文本框宽席
  227. 7、文本框高度
  228. */
  229. //pm_advmarquee: '1,2,50,-60,50,18,0,0x000000,50,0,20,1,15,2000',
  230. pm_advmarquee: '1,2,50,-70,50,20,0,0x000000,50,0,20,1,30,2000',
  231. /*
  232. 滚动广告的控制,要使用的话需要在setup里的第9个参数设置成1
  233. 这里分二种情况,前六个参数是定位控制,第7个参数是设置定位方式(0:相对定位,1:绝对定位)
  234. 第一种情况:第7个参数是0的时候,相对定位,就是播放器长宽变化的时候,控制栏也跟着变
  235. 1、默认1:中间对齐
  236. 2、上中下对齐(0是上,1是中,2是下)
  237. 3、离左边的距离
  238. 4、Y轴偏移量
  239. 5、离右边的距离
  240. 6、高度
  241. 7、定位方式
  242. 第二种情况:第7个参数是1的时候,绝对定位,就是播放器长宽变化的时候,控制栏不跟着变,这种方式一般使用在控制栏大小不变的时候
  243. 1、左中右对齐方式(0是左,1是中间,2是右)
  244. 2、上中下对齐(0是上,1是中,2是下)
  245. 3、x偏移量
  246. 4、y偏移量
  247. 5、宽度
  248. 6、高度
  249. 7、定位方式
  250. 以上是前7个参数的作用
  251. 8、是文字广告的背景色
  252. 9、置背景色的透明度
  253. 10、控制滚动方向,0是水平滚动(包括左右),1是上下滚动(包括向上和向下)
  254. 11、移动的单位时长,即移动单位像素所需要的时长,毫秒
  255. 12、移动的单位像素,正数同左/上,负数向右/下
  256. 13、是行高,这个在设置向上或向下滚动的时候有用处
  257. 14、控制向上或向下滚动时每次停止的时间
  258. */
  259. pm_glowfilter: '1,0x01485d, 100, 6, 3, 10, 1, 0, 0',
  260. /*
  261. 滚动文字广告是否采用发光滤镜
  262. 1、是否使用发光滤镜,0是不采用,1是使用
  263. 2、(default = 0xFF0000) — 光晕颜色,采用十六进制格式 0xRRGGBB。 默认值为 0xFF0000
  264. 3、(default = 100) — 颜色的 Alpha 透明度值。 有效值为 0 到 100。 例如,25 设置透明度为 25%
  265. 4、(default = 6.0) — 水平模糊量。 有效值为 0 到 255(浮点)。 2 的乘方值(如 2、4、8、16 和 32)经过优化,呈现速度比其它值更快
  266. 5、(default = 6.0) — 垂直模糊量。 有效值为 0 到 255(浮点)。 2 的乘方值(如 2、4、8、16 和 32)经过优化,呈现速度比其它值更快
  267. 6、(default = 2) —光晕的强度。 该值越高,光晕的颜色越深,而且发光与背景之间的对比度也越强。 有效值为 0 到 255
  268. 7、(default = 1) — 应用滤镜的次数
  269. 8、(default = 0) — 指定发光是否为内侧发光。 值 1 指定发光是内侧发光。 值 0 指定发光是外侧发光(对象外缘周围的发光)
  270. 9、(default = 0) — 指定对象是否具有挖空效果。 值为 1 将使对象的填充变为透明,并显示文档的背景颜色
  271. */
  272. advmarquee: escape('{a href="http://www.ckplayer.com"}{font color="#FFFFFF" size="12" face="Microsoft YaHei"}这里可以放文字广告,播放器默认使用这里设置的广告内容,如果不想在这里使用可以清空这里的内容,如果想在页面中实时定义滚动文字广告内容,可以清空这里的内容,然后在页面中设置广告函数。{/font}{/a}'),
  273. /*
  274. 该处是滚动文字广告的内容,如果不想在这里设置,就把这里清空并且在页面中使用js的函数定义function ckmarqueeadv(){return '广告内容'}
  275. */
  276. mainfuntion: '',
  277. /*
  278. 当flashvars里s=3/4时,调用的函数包名称,默认为空,调用时间轴上的函数setAppObj
  279. */
  280. flashplayer: '',
  281. /*
  282. 当flashvars里的s=3/4时,也可以把swf文件放在这里
  283. */
  284. calljs: 'ckplayer_status,ckadjump,playerstop,ckmarqueeadv',
  285. /*
  286. 1、全局监听返回结果的函数
  287. 2、跳过广告的函数
  288. 3、播放结束时调用的js函数
  289. 4、加载滚动文字广告的函
  290. */
  291. myweb: escape(''),
  292. /*
  293. ------------------------------------------------------------------------------------------------------------------
  294. 以下内容部份是和插件相关的配置,请注意,自定义插件以及其配置的命名方式要注意,不要和系统的相重复,不然就会替换掉系统的相关设置,删除相关插件的话也可以同时删除相关的配置
  295. ------------------------------------------------------------------------------------------------------------------
  296. 以下内容定义自定义插件的相关配置,这里也可以自定义任何自己的插件需要配置的内容,当然,如果你某个插件不使用的话,也可以删除相关的配置
  297. ------------------------------------------------------------------------------------------------------------------
  298. */
  299. cpt_lights: '',//'1',
  300. /*
  301. 该处定义是否使用开关灯,使用开灯效果时调用页面的js函数function closelights(){},关灯调用 function closelights(){};
  302. */
  303. cpt_share: '',//'ckplayer/share.xml',
  304. /*
  305. 分享插件调用的配置文件地址,此设设置成空,则不启用分享按钮
  306. 调用插件开始
  307. */
  308. cpt_list: ckcpt()
  309. /*
  310. ckcpt()是本文件最上方的定义插件的函数
  311. */
  312. }
  313. return ck;
  314. }
  315. /*
  316. html5部分开始
  317. 以下代码是支持html5的,如果你不需要,可以删除。
  318. html5代码块的代码可以随意更改以适合你的应用,欢迎到论坛交流更改心得
  319. */
  320. (function () {
  321. var CKobject = {
  322. _K_: function (d) {
  323. return document.getElementById(d);
  324. },
  325. _T_: false,
  326. _M_: false,
  327. _G_: false,
  328. _Y_: false,
  329. _I_: null,
  330. _J_: 0,
  331. _O_: {},
  332. uaMatch: function (u, rMsie, rFirefox, rOpera, rChrome, rSafari, rSafari2, mozilla, mobile) {
  333. var match = rMsie.exec(u);
  334. if (match != null) {
  335. return {
  336. b: 'IE',
  337. v: match[2] || '0'
  338. }
  339. }
  340. match = rFirefox.exec(u);
  341. if (match != null) {
  342. return {
  343. b: match[1] || '',
  344. v: match[2] || '0'
  345. }
  346. }
  347. match = rOpera.exec(u);
  348. if (match != null) {
  349. return {
  350. b: match[1] || '',
  351. v: match[2] || '0'
  352. }
  353. }
  354. match = rChrome.exec(u);
  355. if (match != null) {
  356. return {
  357. b: match[1] || '',
  358. v: match[2] || '0'
  359. }
  360. }
  361. match = rSafari.exec(u);
  362. if (match != null) {
  363. return {
  364. b: match[2] || '',
  365. v: match[1] || '0'
  366. }
  367. }
  368. match = rSafari2.exec(u);
  369. if (match != null) {
  370. return {
  371. b: match[1] || '',
  372. v: match[2] || '0'
  373. }
  374. }
  375. match = mozilla.exec(u);
  376. if (match != null) {
  377. return {
  378. b: match[1] || '',
  379. v: match[2] || '0'
  380. }
  381. }
  382. match = mobile.exec(u);
  383. if (match != null) {
  384. return {
  385. b: match[1] || '',
  386. v: match[2] || '0'
  387. }
  388. } else {
  389. return {
  390. b: 'unknown',
  391. v: '0'
  392. }
  393. }
  394. },
  395. browser: function () {
  396. var u = navigator.userAgent,
  397. rMsie = /(msie\s|trident.*rv:)([\w.]+)/,
  398. rFirefox = /(firefox)\/([\w.]+)/,
  399. rOpera = /(opera).+version\/([\w.]+)/,
  400. rChrome = /(chrome)\/([\w.]+)/,
  401. rSafari = /version\/([\w.]+).*(safari)/,
  402. rSafari2 = /(safari)\/([\w.]+)/,
  403. mozilla = /(mozilla)\/([\w.]+)/,
  404. mobile = /(mobile)\/([\w.]+)/;
  405. var c = u.toLowerCase();
  406. var d = this.uaMatch(c, rMsie, rFirefox, rOpera, rChrome, rSafari, rSafari2, mozilla, mobile);
  407. if (d.b) {
  408. b = d.b;
  409. v = d.v;
  410. }
  411. return {B: b, V: v};
  412. },
  413. Platform: function () {
  414. var w = '';
  415. var u = navigator.userAgent,
  416. app = navigator.appVersion;
  417. var b = {
  418. iPhone: u.indexOf('iPhone') > -1 || u.indexOf('Mac') > -1,
  419. iPad: u.indexOf('iPad') > -1,
  420. ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/),
  421. android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1,
  422. webKit: u.indexOf('AppleWebKit') > -1,
  423. trident: u.indexOf('Trident') > -1,
  424. gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1,
  425. presto: u.indexOf('Presto') > -1,
  426. mobile: !!u.match(/AppleWebKit.*Mobile.*/) || !!u.match(/AppleWebKit/),
  427. webApp: u.indexOf('Safari') == -1
  428. };
  429. for (var k in b) {
  430. if (b[k]) {
  431. w = k;
  432. break;
  433. }
  434. }
  435. return w;
  436. },
  437. isHTML5: function () {
  438. return !!document.createElement('video').canPlayType;
  439. },
  440. getType: function () {
  441. return this._T_;
  442. },
  443. getVideo: function () {
  444. var v = '';
  445. var s = this._E_['v'];
  446. if (s && s.length > 1) {
  447. for (var i = 0; i < s.length; i++) {
  448. var a = s[i].split('->');
  449. if (a.length >= 1 && a[0] != '') {
  450. v += '<source src="' + a[0] + '"';
  451. }
  452. if (a.length >= 2 && a[1] != '') {
  453. v += ' type="' + a[1] + '"';
  454. }
  455. v += '>';
  456. }
  457. }
  458. return v;
  459. },
  460. getVars: function (k) {
  461. var o = this._A_;
  462. if (typeof (o) == 'undefined') {
  463. return null;
  464. }
  465. if (k in o) {
  466. return o[k];
  467. } else {
  468. return null;
  469. }
  470. },
  471. getParams: function () {
  472. var p = '';
  473. if (this._A_) {
  474. if (parseInt(this.getVars('p')) == 1) {
  475. p += ' autoplay="autoplay"';
  476. }
  477. if (parseInt(this.getVars('e')) == 1) {
  478. p += ' loop="loop"';
  479. }
  480. if (parseInt(this.getVars('p')) == 2) {
  481. p += ' preload="metadata"';
  482. }
  483. if (this.getVars('i')) {
  484. p += ' poster="' + this.getVars('i') + '"';
  485. }
  486. }
  487. return p;
  488. },
  489. getpath: function (z) {
  490. var f = 'CDEFGHIJKLMNOPQRSTUVWXYZcdefghijklmnopqrstuvwxyz';
  491. var w = z.substr(0, 1);
  492. if (f.indexOf(w) > -1 && (z.substr(0, 4) == w + '://' || z.substr(0, 4) == w + ':\\')) {
  493. return z;
  494. }
  495. var d = unescape(window.location.href).replace('file:///', '');
  496. var k = parseInt(document.location.port);
  497. var u = document.location.protocol + '//' + document.location.hostname;
  498. var l = '',
  499. e = '',
  500. t = '';
  501. var s = 0;
  502. var r = unescape(z).split('//');
  503. if (r.length > 0) {
  504. l = r[0] + '//'
  505. }
  506. var h = 'http|https|ftp|rtsp|mms|ftp|rtmp|file';
  507. var a = h.split('|');
  508. if (k != 80 && k) {
  509. u += ':' + k;
  510. }
  511. for (i = 0; i < a.length; i++) {
  512. if ((a[i] + '://') == l) {
  513. s = 1;
  514. break;
  515. }
  516. }
  517. if (s == 0) {
  518. if (z.substr(0, 1) == '/') {
  519. t = u + z;
  520. } else {
  521. e = d.substring(0, d.lastIndexOf('/') + 1).replace('\\', '/');
  522. var w = z.replace('../', './');
  523. var u = w.split('./');
  524. var n = u.length;
  525. var r = w.replace('./', '');
  526. var q = e.split('/');
  527. var j = q.length - n;
  528. for (i = 0; i < j; i++) {
  529. t += q[i] + '/';
  530. }
  531. t += r;
  532. }
  533. } else {
  534. t = z;
  535. }
  536. return t;
  537. },
  538. getXhr: function () {
  539. var x;
  540. try {
  541. x = new ActiveXObject('Msxml2.XMLHTTP');
  542. } catch (e) {
  543. try {
  544. x = new ActiveXObject('Microsoft.XMLHTTP');
  545. } catch (e) {
  546. x = false;
  547. }
  548. }
  549. if (!x && typeof XMLHttpRequest != 'undefined') {
  550. x = new XMLHttpRequest();
  551. }
  552. return x;
  553. },
  554. getX: function () {
  555. var f = 'ckstyle()';
  556. if (this.getVars('x') && parseInt(this.getVars('c')) != 1) {
  557. f = this.getVars('x') + '()';
  558. }
  559. try {
  560. if (typeof (eval(f)) == 'object') {
  561. this._X_ = eval(f);
  562. }
  563. } catch (e) {
  564. try {
  565. if (typeof (eval(ckstyle)) == 'object') {
  566. this._X_ = ckstyle();
  567. }
  568. } catch (e) {
  569. this._X_ = ckstyle();
  570. }
  571. }
  572. },
  573. getSn: function (s, n) {
  574. if (n >= 0) {
  575. return this._X_[s].split(',')[n];
  576. } else {
  577. return this._X_[s];
  578. }
  579. },
  580. getUrl: function (L, B) {
  581. var C = this;
  582. var b = ['get', 'utf-8'];
  583. if (L && L.length == 2) {
  584. var a = L[0];
  585. var c = L[1].split('/');
  586. if (c.length >= 2) {
  587. b[0] = c[1];
  588. }
  589. if (c.length >= 3) {
  590. b[1] = c[2];
  591. }
  592. this.ajax(b[0], b[1], a,
  593. function (s) {
  594. if (s && s != 'error') {
  595. var d = '',
  596. e = s;
  597. if (s.indexOf('}') > -1) {
  598. var f = s.split('}');
  599. for (var i = 0; i < f.length - 1; i++) {
  600. d += f[i] + '}';
  601. var h = f[i].replace('{', '').split('->');
  602. if (h.length == 2) {
  603. C._A_[h[0]] = h[1];
  604. }
  605. }
  606. e = f[f.length - 1];
  607. }
  608. C._E_['v'] = e.split(',');
  609. if (B) {
  610. C.showHtml5();
  611. } else {
  612. C.changeParams(d);
  613. C.newAdr();
  614. }
  615. }
  616. });
  617. }
  618. },
  619. getflashvars: function (s) {
  620. var v = '',
  621. i = 0;
  622. if (s) {
  623. for (var k in s) {
  624. if (i > 0) {
  625. v += '&';
  626. }
  627. if (k == 'f' && s[k] && !this.getSn('pm_repc', -1)) {
  628. s[k] = this.getpath(s[k]);
  629. if (s[k].indexOf('&') > -1) {
  630. s[k] = encodeURIComponent(s[k]);
  631. }
  632. }
  633. if (k == 'y' && s[k]) {
  634. s[k] = this.getpath(s[k]);
  635. }
  636. v += k + '=' + s[k];
  637. i++;
  638. }
  639. }
  640. return v;
  641. },
  642. getparam: function (s) {
  643. var w = '',
  644. v = '',
  645. o = {
  646. allowScriptAccess: 'always',
  647. allowFullScreen: true,
  648. quality: 'high',
  649. bgcolor: '#000'
  650. };
  651. if (s) {
  652. for (var k in s) {
  653. o[k] = s[k];
  654. }
  655. }
  656. for (var e in o) {
  657. w += e + '="' + o[e] + '" ';
  658. v += '<param name="' + e + '" value="' + o[e] + '" />';
  659. }
  660. w = w.replace('movie=', 'src=');
  661. return {
  662. w: w,
  663. v: v
  664. };
  665. },
  666. getObjectById: function (s) {
  667. var C = this;
  668. if (C._T_) {
  669. C._V_ = C._K_(s)
  670. return C;
  671. }
  672. var x = null,
  673. y = C._K_(s),
  674. r = 'embed';
  675. if (y && y.nodeName == 'OBJECT') {
  676. if (typeof y.SetVariable != 'undefined') {
  677. x = y;
  678. } else {
  679. var z = y.getElementsByTagName(r)[0];
  680. if (z) {
  681. x = z;
  682. }
  683. }
  684. }
  685. return x;
  686. },
  687. ajax: function (b, u, s, f) {
  688. var x = this.getXhr();
  689. var a = [],
  690. m = '';
  691. if (b == 'get') {
  692. if (s.indexOf('?') > -1) {
  693. m = s + '&t=' + new Date().getTime();
  694. } else {
  695. m = s + '?t=' + new Date().getTime();
  696. }
  697. x.open('get', m);
  698. } else {
  699. a = s.split('?');
  700. s = a[0],
  701. m = a[1];
  702. x.open('post', s, true);
  703. }
  704. x.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
  705. x.setRequestHeader('charset', u);
  706. if (b == 'post') {
  707. x.send(m);
  708. } else {
  709. x.send(null);
  710. }
  711. x.onreadystatechange = function () {
  712. if (x.readyState == 4) {
  713. var g = x.responseText;
  714. if (g != '') {
  715. f(g);
  716. } else {
  717. f(null);
  718. }
  719. }
  720. }
  721. },
  722. addListener: function (e, f) {
  723. var o = this._V_;
  724. switch (e) {
  725. case 'time':
  726. e = 'timeupdate';
  727. this.AT = f;
  728. f = this.addListenerTime;
  729. break;
  730. case 'totaltime':
  731. this.ATAll = f;
  732. return;
  733. break;
  734. default:
  735. break;
  736. }
  737. //console.log(typeof(f));
  738. if (typeof (f) == 'string') {
  739. f = eval(f);
  740. }
  741. if (o.addEventListener) {
  742. try {
  743. o.addEventListener(e, f, false);
  744. } catch (e) {
  745. this.getNot();
  746. }
  747. } else if (o.attachEvent) {
  748. try {
  749. o.attachEvent('on' + e, f);
  750. } catch (e) {
  751. this.getNot();
  752. }
  753. } else {
  754. o['on' + e] = f;
  755. }
  756. },
  757. removeListener: function (e, f) {
  758. var o = this._V_;
  759. switch (e) {
  760. case 'time':
  761. e = 'timeupdate';
  762. this.AT = null;
  763. break;
  764. case 'totaltime':
  765. this.ATAll = null;
  766. return;
  767. break;
  768. default:
  769. break;
  770. }
  771. if (typeof (f) == 'string') {
  772. f = eval(f);
  773. }
  774. if (o.removeEventListener) {
  775. try {
  776. o.removeEventListener(e, f, false);
  777. } catch (e) {
  778. this.getNot();
  779. }
  780. } else if (o.detachEvent) {
  781. try {
  782. o.detachEvent('on' + e, f);
  783. } catch (e) {
  784. this.getNot();
  785. }
  786. } else {
  787. o['on' + e] = null;
  788. }
  789. },
  790. Flash: function () {
  791. var f = false, v = 0;
  792. if (document.all || this.browser()['B'].toLowerCase().indexOf('ie') > -1) {
  793. try {
  794. var s = new ActiveXObject('ShockwaveFlash.ShockwaveFlash');
  795. f = true;
  796. var z = s.GetVariable('$version');
  797. v = parseInt(z.split(' ')[1].split(',')[0]);
  798. } catch (e) {
  799. }
  800. } else {
  801. if (navigator.plugins && navigator.plugins.length > 0) {
  802. var s = navigator.plugins['Shockwave Flash'];
  803. if (s) {
  804. f = true;
  805. var w = s.description.split(' ');
  806. for (var i = 0; i < w.length; ++i) {
  807. if (isNaN(parseInt(w[i]))) continue;
  808. v = parseInt(w[i]);
  809. }
  810. }
  811. }
  812. }
  813. return {
  814. f: f,
  815. v: v
  816. };
  817. },
  818. embed: function (f, d, i, w, h, b, v, e, p, j) {
  819. var s = ['all'];
  820. if (b) {
  821. if (this.isHTML5()) {
  822. this.embedHTML5(d, i, w, h, e, v, s, j);
  823. } else {
  824. this.embedSWF(f, d, i, w, h, v, p);
  825. }
  826. } else {
  827. if (this.Flash()['f'] && parseInt(this.Flash()['v']) > 10) {
  828. this.embedSWF(f, d, i, w, h, v, p);
  829. } else if (this.isHTML5()) {
  830. this.embedHTML5(d, i, w, h, e, v, s, j);
  831. } else {
  832. this.embedSWF(f, d, i, w, h, v, p);
  833. }
  834. }
  835. },
  836. embedSWF: function (C, D, N, W, H, V, P) {
  837. if (!N) {
  838. N = 'ckplayer_a1'
  839. }
  840. if (!P) {
  841. P = {
  842. bgcolor: '#FFF',
  843. allowFullScreen: true,
  844. allowScriptAccess: 'always',
  845. wmode: 'transparent'
  846. };
  847. }
  848. this._A_ = V;
  849. this.getX();
  850. var u = 'undefined',
  851. g = false,
  852. j = document,
  853. r = 'http://www.macromedia.com/go/getflashplayer',
  854. t = '<a href="' + r + '" target="_blank">请点击此处下载安装最新的flash插件</a>',
  855. error = {
  856. w: '您的网页不符合w3c标准,无法显示播放器',
  857. f: '您没有安装flash插件,无法播放视频,' + t,
  858. v: '您的flash插件版本过低,无法播放视频,' + t
  859. },
  860. w3c = typeof j.getElementById != u && typeof j.getElementsByTagName != u && typeof j.createElement != u,
  861. i = 'id="' + N + '" name="' + N + '" ',
  862. s = '',
  863. l = '';
  864. P['movie'] = C;
  865. P['flashvars'] = this.getflashvars(V);
  866. if (W == -1) {
  867. d = true;
  868. this._K_(D).style.width = '100%';
  869. W = '100%';
  870. }
  871. s += '<object pluginspage="http://www.macromedia.com/go/getflashplayer" ';
  872. s += 'classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" ';
  873. s += 'codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=11,3,0,0" ';
  874. s += 'width="' + W + '" ';
  875. s += 'height="' + H + '" ';
  876. s += i;
  877. s += 'align="middle">';
  878. s += this.getparam(P)['v'];
  879. s += '<embed ';
  880. s += this.getparam(P)['w'];
  881. s += ' width="' + W + '" height="' + H + '" name="' + N + '" id="' + N + '" align="middle" ' + i;
  882. s += 'type="application/x-shockwave-flash" pluginspage="' + r + '" />';
  883. s += '</object>';
  884. if (!w3c) {
  885. l = error['w'];
  886. g = true;
  887. } else {
  888. if (!this.Flash()['f']) {
  889. l = error['f'];
  890. g = true;
  891. } else {
  892. if (this.Flash()['v'] < 11) {
  893. l = error['v'];
  894. g = true;
  895. } else {
  896. l = s;
  897. this._T_ = false;
  898. }
  899. }
  900. }
  901. if (l) {
  902. this._K_(D).innerHTML = l;
  903. }
  904. if (g) {
  905. this._K_(D).style.color = '#0066cc';
  906. this._K_(D).style.lineHeight = this._K_(D).style.height;
  907. this._K_(D).style.textAlign = 'center';
  908. }
  909. },
  910. embedHTML5: function (C, P, W, H, V, A, S, J) {
  911. this._E_ = {
  912. c: C,
  913. p: P,
  914. w: W,
  915. h: H,
  916. v: V,
  917. s: S,
  918. j: J == undefined || J ? true : false
  919. };
  920. this._A_ = A;
  921. this.getX();
  922. b = this.browser()['B'],
  923. v = this.browser()['V'],
  924. x = v.split('.'),
  925. t = x[0],
  926. m = b + v,
  927. n = b + t,
  928. w = '',
  929. s = false,
  930. f = this.Flash()['f'],
  931. a = false;
  932. if (!S) {
  933. S = ['iPad', 'iPhone', 'ios'];
  934. }
  935. for (var i = 0; i < S.length; i++) {
  936. w = S[i];
  937. if (w.toLowerCase() == 'all') {
  938. s = true;
  939. break;
  940. }
  941. if (w.toLowerCase() == 'all+false' && !f) {
  942. s = true;
  943. break;
  944. }
  945. if (w.indexOf('+') > -1) {
  946. w = w.split('+')[0];
  947. a = true;
  948. } else {
  949. a = false;
  950. }
  951. if (this.Platform() == w || m == w || n == w || b == w) {
  952. if (a) {
  953. if (!f) {
  954. s = true;
  955. break;
  956. }
  957. } else {
  958. s = true;
  959. break;
  960. }
  961. }
  962. }
  963. if (s) {
  964. if (V) {
  965. var l = V[0].split('->');
  966. if (l && l.length == 2 && l[1].indexOf('ajax') > -1) {
  967. this.getUrl(l, true);
  968. return;
  969. }
  970. }
  971. this.showHtml5();
  972. }
  973. },
  974. status: function () {
  975. this._H_ = parseInt(this.getSn('setup', 20));
  976. var f = 'ckplayer_status';
  977. if (this.getSn('calljs', 0) != '') {
  978. f = this.getSn('calljs', 0);
  979. }
  980. try {
  981. if (typeof (eval(f)) == 'function') {
  982. this._L_ = eval(f);
  983. this._M_ = true;
  984. return true;
  985. }
  986. } catch (e) {
  987. try {
  988. if (typeof (eval(ckplayer_status)) == 'function') {
  989. this._L_ = ckplayer_status;
  990. this._M_ = true;
  991. return true;
  992. }
  993. } catch (e) {
  994. return false;
  995. }
  996. }
  997. return false;
  998. },
  999. showHtml5: function () {
  1000. var C = this;
  1001. var p = C._E_['p'],
  1002. a = C._E_['v'],
  1003. c = C._E_['c'],
  1004. j = '',
  1005. b = false;
  1006. var s = this._E_['v'];
  1007. var w = C._E_['w'], h = C._E_['h'];
  1008. var d = false;
  1009. var r = '';
  1010. if (s.length == 1) {
  1011. r = ' src="' + s[0].split('->')[0] + '"';
  1012. }
  1013. if (w == -1) {
  1014. d = true;
  1015. C._K_(c).style.width = '100%';
  1016. w = '100%';
  1017. }
  1018. if (w.toString().indexOf('%') > -1) {
  1019. w = '100%';
  1020. }
  1021. if (h.toString().indexOf('%') > -1) {
  1022. h = '100%';
  1023. }
  1024. if (C._E_['j']) {
  1025. j = ' controls="controls"';
  1026. }
  1027. var v = '<video' + j + r + ' id="' + p + '" width="' + w + '" height="' + h + '"' + C.getParams() + ' webkit-playsinline>' + C.getVideo() + '</video>';
  1028. C._K_(c).innerHTML = v;
  1029. C._K_(c).style.backgroundColor = '#000';
  1030. C._V_ = C._K_(p);
  1031. if (!d) {
  1032. C._K_(c).style.width = C._E_['w'].toString().indexOf('%') > -1 ? (C._K_(c).offsetWidth * parseInt(C._E_['w']) * 0.01) + 'px' : C._V_.width + 'px';
  1033. C._K_(c).style.height = C._E_['h'].toString().indexOf('%') > -1 ? (C._K_(c).offsetHeight * parseInt(C._E_['h']) * 0.01) + 'px' : C._V_.height + 'px';
  1034. }
  1035. C._P_ = false;
  1036. C._T_ = true;
  1037. if (C.getVars('loaded') != '') {
  1038. var f = C.getVars('loaded') + '()';
  1039. try {
  1040. if (typeof (eval(f)) == 'function') {
  1041. eval(f);
  1042. }
  1043. } catch (e) {
  1044. try {
  1045. if (typeof (eval(loadedHandler)) == 'function') {
  1046. loadedHandler();
  1047. }
  1048. } catch (e) {
  1049. }
  1050. }
  1051. }
  1052. C.status();
  1053. C.addListener('play', C.playHandler);
  1054. C.addListener('pause', C.playHandler);
  1055. C.addListener('error', C.errorHandler);
  1056. C.addListener('emptied', C.errorHandler);
  1057. C.addListener('loadedmetadata', C.loadedMetadataHandler);
  1058. C.addListener('ended', C.endedHandler);
  1059. C.addListener('volumechange', C.volumeChangeHandler);
  1060. if ((C.getVars('m') != '' && C.getVars('m') != null) || parseInt(C.getSn('setup', 0)) > 0) {
  1061. C._K_(c).style.cursor = 'pointer';
  1062. }
  1063. if ((C.getVars('m') != '' && C.getVars('m') != null) || parseInt(C.getSn('setup', 1)) == 1) {
  1064. C.addListener('click', C.html5Click);
  1065. }
  1066. },
  1067. addListenerTime: function () {
  1068. var C = CKobject;
  1069. if (C.AT) {
  1070. C.AT(C._V_['currentTime']);
  1071. }
  1072. },
  1073. videoPlay: function () {
  1074. if (this._T_) {
  1075. this._V_.play();
  1076. }
  1077. },
  1078. videoPause: function () {
  1079. if (this._T_) {
  1080. this._V_.pause();
  1081. }
  1082. },
  1083. playOrPause: function () {
  1084. if (this._T_) {
  1085. if (this._V_.paused) {
  1086. this._V_.play();
  1087. } else {
  1088. this._V_.pause();
  1089. }
  1090. }
  1091. },
  1092. fastNext: function () {
  1093. if (this._T_) {
  1094. this._V_['currentTime'] = this._V_['currentTime'] + 10;
  1095. }
  1096. },
  1097. fastBack: function () {
  1098. if (this._T_) {
  1099. this._V_['currentTime'] = this._V_['currentTime'] - 10;
  1100. }
  1101. },
  1102. changeVolume: function (n) {
  1103. if (n < 0 || n > 100) {
  1104. return;
  1105. }
  1106. if (this._T_) {
  1107. this._V_['volume'] = n * 0.01;
  1108. }
  1109. },
  1110. videoSeek: function (t) {
  1111. if (this._T_) {
  1112. this._V_['currentTime'] = t;
  1113. }
  1114. },
  1115. newAddress: function (u) {
  1116. var s = [];
  1117. if (u) {
  1118. s = this.isHtml5New(u);
  1119. } else {
  1120. return;
  1121. }
  1122. if (s && this._T_) {
  1123. this.changeParams(u);
  1124. var l = s[0].split('->');
  1125. if (l && l.length == 2 && l[1].indexOf('ajax') > -1) {
  1126. this.getUrl(l, false);
  1127. return;
  1128. }
  1129. this._E_['v'] = s;
  1130. this.newAdr();
  1131. }
  1132. },
  1133. quitFullScreen: function () {
  1134. if (document.cancelFullScreen) {
  1135. document.cancelFullScreen();
  1136. } else if (document.mozCancelFullScreen) {
  1137. document.mozCancelFullScreen();
  1138. } else if (document.webkitCancelFullScreen) {
  1139. document.webkitCancelFullScreen();
  1140. }
  1141. },
  1142. changeStatus: function (n) {
  1143. this._H_ = n;
  1144. },
  1145. newAdr: function () {
  1146. var s = this._E_['v'];
  1147. this._V_.pause();
  1148. if (s.length == 1) {
  1149. this._V_.src = s[0].split('->')[0];
  1150. } else {
  1151. this._V_['innerHTML'] = this.getVideo();
  1152. }
  1153. this._V_.load();
  1154. },
  1155. isHtml5New: function (s) {
  1156. if (s.indexOf('html5') == -1) {
  1157. return false;
  1158. }
  1159. var a = s.replace(/{/g, '');
  1160. var b = a.split('}');
  1161. var c = '';
  1162. for (var i = 0; i < b.length; i++) {
  1163. if (b[i].indexOf('html5') > -1) {
  1164. c = b[i].replace('html5->', '').split(',');
  1165. break;
  1166. }
  1167. }
  1168. return c;
  1169. },
  1170. changeParams: function (f) {
  1171. if (f) {
  1172. var a = f.replace(/{/g, '');
  1173. var b = a.split('}');
  1174. var c = '';
  1175. for (var i = 0; i < b.length; i++) {
  1176. var d = b[i].split('->');
  1177. if (d.length == 2) {
  1178. switch (d[0]) {
  1179. case 'p':
  1180. if (parseInt(d[1]) == 1) {
  1181. this._V_.autoplay = true;
  1182. } else if (parseInt(d[1]) == 2) {
  1183. this._V_.preload = 'metadata';
  1184. } else {
  1185. this._V_.autoplay = false;
  1186. if (this._I_ != null) {
  1187. clearInterval(this._I_);
  1188. this._I_ = null;
  1189. }
  1190. }
  1191. break;
  1192. case 'e':
  1193. if (parseInt(d[1]) == 1) {
  1194. this._V_.loop = true;
  1195. } else {
  1196. this._V_.loop = false;
  1197. }
  1198. break;
  1199. case 'i':
  1200. this._V_.poster = d[1];
  1201. break;
  1202. default:
  1203. break;
  1204. }
  1205. }
  1206. }
  1207. }
  1208. },
  1209. frontAdPause: function (s) {
  1210. this.getNot();
  1211. },
  1212. frontAdUnload: function () {
  1213. this.getNot();
  1214. },
  1215. changeFace: function (s) {
  1216. this.getNot();
  1217. },
  1218. plugin: function (a, b, c, d, e, f, g) {
  1219. this.getNot();
  1220. },
  1221. videoClear: function () {
  1222. this.getNot();
  1223. },
  1224. videoBrightness: function (s) {
  1225. this.getNot();
  1226. },
  1227. videoContrast: function (s) {
  1228. this.getNot();
  1229. },
  1230. videoSaturation: function (s) {
  1231. this.getNot();
  1232. },
  1233. videoSetHue: function (s) {
  1234. this.getNot();
  1235. },
  1236. videoWAndH: function (a, b) {
  1237. this.getNot();
  1238. },
  1239. videoWHXY: function (a, b, c, d) {
  1240. this.getNot();
  1241. },
  1242. changeFlashvars: function (a) {
  1243. this.getNot();
  1244. },
  1245. changeMyObject: function (a, b) {
  1246. this.getNot();
  1247. },
  1248. getMyObject: function (a, b) {
  1249. this.getNot();
  1250. },
  1251. changeeFace: function () {
  1252. this.getNot();
  1253. },
  1254. changeStyle: function (a, b) {
  1255. this.getNot();
  1256. },
  1257. promptLoad: function () {
  1258. this.getNot();
  1259. },
  1260. promptUnload: function () {
  1261. this.getNot();
  1262. },
  1263. marqueeLoad: function (a, b) {
  1264. this.getNot();
  1265. },
  1266. marqueeClose: function (s) {
  1267. this.getNot();
  1268. },
  1269. videoError: function (s) {
  1270. this.getNot();
  1271. },
  1272. formatUrl: function (s) {
  1273. this.getNot();
  1274. },
  1275. sendJS: function (s) {
  1276. this.getNot();
  1277. },
  1278. plugAttribute: function (s) {
  1279. this.getNot();
  1280. },
  1281. errorTextShow: function (s) {
  1282. this.getNot();
  1283. },
  1284. openUrl: function (s) {
  1285. window.open(s);
  1286. },
  1287. jsonParse: function (s) {
  1288. this.getNot();
  1289. },
  1290. promptShow: function (s, x, y) {
  1291. this.getNot();
  1292. },
  1293. screenShot: function (s, x, y, x2, y2) {
  1294. this.getNot();
  1295. },
  1296. fullScreen: function () {
  1297. this.getNot();
  1298. },
  1299. allowFull: function () {
  1300. this.getNot();
  1301. },
  1302. loadButton: function () {
  1303. this.getNot();
  1304. },
  1305. getFile: function () {
  1306. this.getNot();
  1307. },
  1308. textBoxShow: function () {
  1309. this.getNot();
  1310. },
  1311. loadElement: function () {
  1312. this.getNot();
  1313. },
  1314. textBoxClose: function () {
  1315. this.getNot();
  1316. },
  1317. textBoxTween: function () {
  1318. this.getNot();
  1319. },
  1320. getNot: function () {
  1321. var s = 'The ckplayer\'s API for HTML5 does not exist';
  1322. return s;
  1323. },
  1324. volumeChangeHandler: function () {
  1325. var C = CKobject;
  1326. if (C._V_.muted) {
  1327. C.returnStatus('volumechange:0', 1);
  1328. C._O_['volume'] = 0;
  1329. C._O_['mute'] = true;
  1330. } else {
  1331. C._O_['mute'] = false;
  1332. C._O_['volume'] = C._V_['volume'] * 100;
  1333. C.returnStatus('volumechange:' + C._V_['volume'] * 100, 1);
  1334. }
  1335. },
  1336. endedHandler: function () {
  1337. var C = CKobject;
  1338. var e = parseInt(C.getVars('e'));
  1339. C.returnStatus('ended', 1);
  1340. if (C._I_) {
  1341. clearInterval(C._I_);
  1342. C._I_ = null;
  1343. }
  1344. if (e != 0 && e != 4 && e != 6) {
  1345. return;
  1346. }
  1347. if (e == 6) {
  1348. this.quitFullScreen();
  1349. }
  1350. var f = 'playerstop()';
  1351. if (C.getSn('calljs', 2) != '') {
  1352. f = C.getSn('calljs', 2) + '()';
  1353. }
  1354. try {
  1355. if (typeof (eval(f)) == 'function') {
  1356. eval(f);
  1357. return;
  1358. }
  1359. } catch (e) {
  1360. try {
  1361. if (typeof (eval(playerstop)) == 'function') {
  1362. playerstop();
  1363. return;
  1364. }
  1365. } catch (e) {
  1366. return;
  1367. }
  1368. }
  1369. },
  1370. loadedMetadataHandler: function () {
  1371. var C = CKobject;
  1372. C.returnStatus('loadedmetadata', 1);
  1373. C._O_['totalTime'] = C._V_['duration'];
  1374. C._O_['width'] = C._V_['width'];
  1375. C._O_['height'] = C._V_['height'];
  1376. C._O_['awidth'] = C._V_['videoWidth'];
  1377. C._O_['aheight'] = C._V_['videoHeight'];
  1378. if (C._V_.defaultMuted) {
  1379. C.returnStatus('volumechange:0', 1);
  1380. C._O_['mute'] = true;
  1381. C._O_['volume'] = 0;
  1382. } else {
  1383. C._O_['mute'] = false;
  1384. C._O_['volume'] = C._V_['volume'] * 100;
  1385. C.returnStatus('volumechange:' + C._V_['volume'] * 100, 1);
  1386. }
  1387. if (parseInt(C.getVars('p')) == 1) {
  1388. C.playHandler();
  1389. }
  1390. if (C.ATAll) {
  1391. C.ATAll(C._V_['duration']);
  1392. }
  1393. },
  1394. errorHandler: function () {
  1395. CKobject.returnStatus('error', 1);
  1396. },
  1397. playHandler: function () {
  1398. var C = CKobject;
  1399. if (C._V_.paused) {
  1400. C.returnStatus('pause', 1);
  1401. C.addO('play', false);
  1402. if (C._I_ != null) {
  1403. clearInterval(C._I_);
  1404. C._I_ = null;
  1405. }
  1406. } else {
  1407. C.returnStatus('play', 1);
  1408. C.addO('play', true);
  1409. if (!C._P_) {
  1410. C.returnStatus('play', 1);
  1411. C._P_ = true;
  1412. }
  1413. C._I_ = setInterval(C.playTime, parseInt(C.getSn('setup', 37)));
  1414. if (!C._G_) {
  1415. C._G_ = true;
  1416. for (var k in C._A_) {
  1417. if (k == 'g' && C._A_[k]) {
  1418. var g = parseInt(C._A_[k]);
  1419. C.videoSeek(g);
  1420. }
  1421. }
  1422. }
  1423. if (!C._Y_) {
  1424. C._Y_ = true;
  1425. for (var k in C._A_) {
  1426. if (k == 'j' && C._A_[k]) {
  1427. var j = parseInt(C._A_[k]);
  1428. if (j > 0) {
  1429. C._J_ = j;
  1430. } else {
  1431. C._J_ = parseInt(C._O_['totalTime']) + j;
  1432. }
  1433. }
  1434. }
  1435. }
  1436. }
  1437. },
  1438. html5Click: function () {
  1439. //console.log(this);
  1440. var C = CKobject;
  1441. if (C.getVars('m') != '' && C.getVars('m') != null) {
  1442. window.open(C.getVars('m'));
  1443. }
  1444. },
  1445. returnStatus: function (s, j) {
  1446. var h = s;
  1447. if (this._H_ == 3) {
  1448. h = this._E_['p'] + '->' + h;
  1449. }
  1450. if (this._M_ && j <= this._H_) {
  1451. this._L_(h);
  1452. }
  1453. },
  1454. addO: function (s, z) {
  1455. this._O_[s] = z;
  1456. },
  1457. getStatus: function () {
  1458. return this._O_;
  1459. },
  1460. playTime: function () {
  1461. var C = CKobject;
  1462. var t = C._V_['currentTime'];
  1463. C._O_['time'] = t;
  1464. if (C._J_ > 0 && t > C._J_) {
  1465. C._J_ = 0;
  1466. C.videoSeek(C._O_['totaltime']);
  1467. }
  1468. C.returnStatus('time:' + t, 1);
  1469. }
  1470. }
  1471. window.CKobject = CKobject;
  1472. })();