12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764 |
- /*
- 软件名称:ckplayer
- 软件版本:X
- 软件作者:http://www.ckplayer.com
- ---------------------------------------------------------------------------------------------
- 开发说明:
- 使用的主要程序语言:javascript(js)及actionscript3.0(as3.0)(as3.0主要用于flashplayer部分的开发,不在该页面呈现)
- 功能:播放视频
- 特点:兼容HTML5-VIDEO(优先)以及FlashPlayer
- =====================================================================================================================
- */
- function ckplayerConfig() {
- return {
- flashvars: {}, //用来补充flashvars里的对象
- languagePath: '', //语言包文件地址
- stylePath: '', //风格包文件地址
- config: {
- fullInteractive: true, //是否开启交互功能
- delay: 30, //延迟加载视频,单位:毫秒
- timeFrequency: 100, //计算当前播放时间和加载量的时间频率,单位:毫秒
- autoLoad: true, //视频是否自动加载
- loadNext: 0, //多段视频预加载的段数,设置成0则全部加载
- definition: true, //是否使用清晰度组件
- smartRemove: true, //是否使用智能清理,使用该功能则在多段时当前播放段之前的段都会被清除出内存,减少对内存的使用
- bufferTime: 200, //缓存区的长度,单位:毫秒,不要小于10
- click: true, //是否支持屏幕单击暂停
- doubleClick: true, //是否支持屏幕双击全屏
- doubleClickInterval: 200, //判断双击的标准,即二次单击间隔的时间差之内判断为是双击,单位:毫秒
- keyDown: {
- space: true, //是否启用空格键切换播放/暂停
- left: true, //是否启用左方向键快退
- right: true, //是否启用右方向键快进
- up: true, //是否支持上方向键增加音量
- down: true //是否支持下方向键减少音量
- },
- timeJump: 10, //快进快退时的秒数
- volumeJump: 0.1, //音量调整的数量,大于0小于1的小数
- timeScheduleAdjust: 1, //是否可调节调节栏,0不启用,1是启用,2是只能前进(向右拖动),3是只能后退,4是只能前进但能回到第一次拖动时的位置,5是看过的地方可以随意拖动
- previewDefaultLoad: true, //预览图片是否默认加载,优点是鼠标第一次经过进度条即可显示预览图片
- promptSpotTime: false, //提示点文字是否在前面加上对应时间
- buttonMode: {
- player: false, //鼠标在播放器上是否显示可点击形态
- controlBar: false, //鼠标在控制栏上是否显示可点击形态
- timeSchedule: true, //鼠标在时间进度条上是否显示可点击形态
- volumeSchedule: true //鼠标在音量调节栏上是否显示可点击形态
- },
- liveAndVod: { //直播+点播=回播功能
- open: false, //是否开启,开启该功能需要设置flashvars里live=true
- vodTime: 2, //可以回看的整点数
- start: 'start' //回看请求参数
- },
- errorNum: 3, //错误重连次数
- playCorrect: false, //是否需要错误修正,这是针对rtmp的
- timeCorrect: true, //http视频播放时间错误纠正,有些因为视频格式的问题导致视频没有实际播放结束视频文件就返回了stop命令
- m3u8Definition: { //m3u8自动清晰度时按关键字来进行判断
- //tags:['200k','110k','400k','600k','1000k']
- },
- m3u8MaxBufferLength: 30, //m3u8每次缓冲时间,单位:秒数
- split: ',', //当视频地址采用字符形式并且需要使用逗号或其它符号来切割数组里定义
- timeStamp: '', //一个地址,用来请求当前时间戳,用于播放器内部时间效准
- addCallback: 'adPlay,adPause,playOrPause,videoPlay,videoPause,videoMute,videoEscMute,videoClear,changeVolume,fastBack,fastNext,videoSeek,newVideo,getMetaDate,videoRotation,videoBrightness,videoContrast,videoSaturation,videoHue,videoZoom,videoProportion,videoError,addListener,removeListener,addElement,getElement,deleteElement,animate,animateResume,animatePause,deleteAnimate,changeConfig,getConfig,openUrl,fullScreen,quitFullScreen,switchFull,screenshot,custom,changeControlBarShow,getCurrentSrc'
- //需要支持的事件
- },
- menu: { //版权名称支持
- ckkey: '',
- name: '',
- link: '',
- version: '',
- domain: '',
- more: []
- },
- style: { //风格部分内容配置,这里主要配置loading和logo以及广告的部分内容
- loading: {
- file: '',
- align: 'center',
- vAlign: 'middle',
- offsetX: -100,
- offsetY: -40
- },
- logo: {
- file: '',
- align: 'right',
- vAlign: 'top',
- offsetX: -100,
- offsetY: 10
- },
- advertisement: { //广告相关的配置
- time: 5, //广告默认播放时长以及多个广告时每个广告默认播放时间,单位:秒
- method: 'get', //广告监测地址默认请求方式,get/post
- videoForce: false, //频广告是否强制播放结束
- videoVolume: 0.8, //视频音量
- skipButtonShow: true, //是否显示跳过广告按钮
- linkButtonShow: true, //是否显示广告链接按钮,如果选择显示,只有在提供了广告链接地址时才会显示
- muteButtonShow: true, //是否显示跳过广告按钮
- closeButtonShow: true, //暂停时是否显示关闭广告按钮
- closeOtherButtonShow: true, //其它广告是否需要关闭广告按钮
- frontSkipButtonDelay: 0, //前置广告跳过广告按钮延时显示的时间,单位:秒
- insertSkipButtonDelay: 0, //插入广告跳过广告按钮延时显示的时间,单位:秒
- endSkipButtonDelay: 0, //后置广告跳过广告按钮延时显示的时间,单位:秒
- frontStretched: 2, //前置广告拉伸方式,0=原始大小,1=自动缩放,2=只有当广告的宽或高大于播放器宽高时才进行缩放,3=参考播放器宽高,4=宽度参考播放器宽、高度自动,5=高度参考播放器高、宽度自动
- insertStretched: 2, //插入广告拉伸方式,0=原始大小,1=自动缩放,2=只有当广告的宽或高大于播放器宽高时才进行缩放,3=参考播放器宽高,4=宽度参考播放器宽、高度自动,5=高度参考播放器高、宽度自动
- pauseStretched: 2, //暂停广告拉伸方式,0=原始大小,1=自动缩放,2=只有当广告的宽或高大于播放器宽高时才进行缩放,3=参考播放器宽高,4=宽度参考播放器宽、高度自动,5=高度参考播放器高、宽度自动
- endStretched: 2 //结束广告拉伸方式,0=原始大小,1=自动缩放,2=只有当广告的宽或高大于播放器宽高时才进行缩放,3=参考播放器宽高,4=宽度参考播放器宽、高度自动,5=高度参考播放器高、宽度自动
- },
- video: { //视频的默认比例
- defaultWidth: 4, //宽度
- defaultHeight: 3 //高度
- }
- }
- };
- }
- !(function() {
- var javascriptPath = '';
- ! function() {
- var scriptList = document.scripts,
- thisPath = scriptList[scriptList.length - 1].src;
- javascriptPath = thisPath.substring(0, thisPath.lastIndexOf('/') + 1);
- }();
- var ckplayer = function(obj) {
- /*
- javascript部分开发所用的注释说明:
- 1:初始化-程序调用时即运行的代码部分
- 2:定义样式-定义容器(div,p,canvas等)的样式表,即css
- 3:监听动作-监听元素节点(单击-click,鼠标进入-mouseover,鼠标离开-mouseout,鼠标移动-mousemove等)事件
- 4:监听事件-监听视频的状态(播放,暂停,全屏,音量调节等)事件
- 5:共用函数-这类函数在外部也可以使用
- 6:全局变量-定义成全局使用的变量
- 7:其它相关注释
- 全局变量说明:
- 在本软件中所使用到的全局变量(变量(类型)包括Boolean,String,Int,Object(包含元素对象和变量对象),Array,Function等)
- 下面列出重要的全局变量:
- V:Object:视频对象
- VA:Array:视频列表(包括视频地址,类型,清晰度说明)
- ID:String:视频ID
- CB:Object:控制栏各元素的集合对象
- PD:Object:内部视频容器对象
- ---------------------------------------------------------------------------------------------
- 程序开始
- 下面为需要初始化配置的全局变量
- 初始化配置
- config:全局变量/变量类型:Object/功能:定义一些基本配置
- */
- this.config = {
- videoClick: true, //是否支持单击播放/暂停动作
- videoDbClick: true, //是否支持双击全屏/退出全屏动作
- errorTime: 100, //延迟判断失败的时间,单位:毫秒
- videoDrawImage: false //是否使用视频drawImage功能,注意,该功能在移动端表现不了
- };
- //全局变量/变量类型:Object/功能:播放器默认配置,在外部传递过来相应配置后,则进行相关替换
- this.varsConfig = {
- playerID: '', //播放器ID
- container: '', //视频容器的ID
- variable: 'ckplayer', //播放函数(变量)名称
- volume: 0.8, //默认音量,范围0-1
- poster: '', //封面图片地址
- autoplay: false, //是否自动播放
- loop: false, //是否需要循环播放
- live: false, //是否是直播
- duration: 0, //指定总时间
- seek: 0, //默认需要跳转的秒数
- drag: '', //拖动时支持的前置参数
- front: '', //前一集按钮动作
- next: '', //下一集按钮动作
- loaded: '', //加载播放器后调用的函数
- flashplayer: false, //设置成true则强制使用flashplayer
- html5m3u8: false, //PC平台上是否使用h5播放器播放m3u8
- track: null, //字幕轨道
- cktrack: null, //ck字幕
- preview: null, //预览图片对象
- prompt: null, //提示点功能
- video: null, //视频地址
- config: '', //调用配置函数名称
- type: '', //视频格式
- crossorigin: '', //设置html5视频的crossOrigin属性
- crossdomain: '', //安全策略文件地址
- unescape: false, //默认flashplayer里需要解码
- mobileCkControls: false, //移动端h5显示控制栏
- playbackrate: 1, //默认倍速
- debug: false //是否开启调试模式
- };
- this.vars = {};
- //全局变量/变量类型:Object/功能:语言配置
- this.language = {
- volume: '音量:',
- play: '点击播放',
- pause: '点击暂停',
- full: '点击全屏',
- escFull: '退出全屏',
- mute: '点击静音',
- escMute: '取消静音',
- front: '上一集',
- next: '下一集',
- definition: '点击选择清晰度',
- playbackRate: '点击选择速度',
- error: '加载出错'
- };
- //全局变量/变量类型:Array/功能:右键菜单:[菜单标题,类型(link:链接,default:灰色,function:调用函数,javascript:调用js函数),执行内容(包含链接地址,函数名称),[line(间隔线)]]
- this.contextMenu = [
- ['ckplayer', 'link', 'http://www.ckplayer.com'],
- ['version:X', 'default', 'line']
- ];
- //全局变量/变量类型:Array/功能:错误列表
- this.errorList = [
- ['000', 'Object does not exist'],
- ['001', 'Variables type is not a object'],
- ['002', 'Video object does not exist'],
- ['003', 'Video object format error'],
- ['004', 'Video object format error'],
- ['005', 'Video object format error'],
- ['006', '[error] does not exist '],
- ['007', 'Ajax error'],
- ['008', 'Ajax error'],
- ['009', 'Ajax object format error'],
- ['010', 'Ajax.status:[error]']
- ];
- //全局变量/变量类型:Array/功能:HTML5变速播放的值数组/如果不需要可以设置成null
- this.playbackRateArr = [
- [0.5, '0.5倍'],
- [1, '正常'],
- [1.25, '1.25倍'],
- [1.5, '1.5倍'],
- [2, '2倍速'],
- [4, '4倍速']
- ];
- //全局变量/变量类型:Array/功能:HTML5默认变速播放的值
- this.playbackRateDefault = 1;
- //全局变量/变量类型:String/功能:定义logo
- this.logo = '';
- //全局变量/变量类型:Boolean/功能:是否加载了播放器
- this.loaded = false;
- //全局变量/变量类型:计时器/功能:监听视频加载出错的状态
- this.timerError = null;
- //全局变量/变量类型:Boolean/功能:是否出错
- this.error = false;
- //全局变量/变量类型:Array/功能:出错地址的数组
- this.errorUrl = [];
- //全局变量/变量类型:计时器/功能:监听全屏与非全屏状态
- this.timerFull = null;
- //全局变量/变量类型:Boolean/功能:是否全屏状态
- this.full = false;
- //全局变量/变量类型:计时器/功能:监听当前的月/日 时=分=秒
- this.timerTime = null;
- //全局变量/变量类型:计时器/功能:监听视频加载
- this.timerBuffer = null;
- //全局变量/变量类型:Boolean/功能:设置进度按钮及进度条是否跟着时间变化,该属性主要用来在按下进度按钮时暂停进度按钮移动和进度条的长度变化
- this.isTimeButtonMove = true;
- //全局变量/变量类型:Boolean/功能:进度栏是否有效,如果是直播,则不需要监听时间让进度按钮和进度条变化
- this.isTimeButtonDown = false;
- //全局变量/变量类型:Boolean/功能:用来模拟双击功能的判断
- this.isClick = false;
- //全局变量/变量类型:计时器/功能:用来模拟双击功能的计时器
- this.timerClick = null;
- //全局变量/变量类型:计时器/功能:旋转loading
- this.timerLoading = null;
- //全局变量/变量类型:计时器/功能:监听鼠标在视频上移动显示控制栏
- this.timerCBar = null;
- //全局变量/变量类型:Int/功能:播放视频时如果该变量的值大于0,则进行跳转后设置该值为0
- this.needSeek = 0;
- //全局变量/变量类型:Int/功能:当前音量
- this.volume = 0;
- //全局变量/变量类型:Int/功能:静音时保存临时音量
- this.volumeTemp = 0;
- //全局变量/变量类型:Number/功能:当前播放时间
- this.time = 0;
- //全局变量/变量类型:Boolean/功能:定义首次调用
- this.isFirst = true;
- //全局变量/变量类型:Boolean/功能:是否使用HTML5-VIDEO播放
- this.html5Video = true;
- //全局变量/变量类型:Object/功能:记录视频容器节点的x;y
- this.pdCoor = {
- x: 0,
- y: 0
- };
- //全局变量/变量类型:String/功能:判断当前使用的播放器类型,html5video或flashplayer
- this.playerType = '';
- //全局变量/变量类型:Int/功能:加载进度条的长度
- this.loadTime = 0;
- //全局变量/body对象
- this.body = document.body || document.documentElement;
- //全局变量/V/播放器
- this.V = null;
- //全局变量/保存外部js监听事件数组
- this.listenerJsArr = [];
- //全局变量/保存控制栏显示元素的总宽度
- this.buttonLen = 0;
- //全局变量/保存控制栏显示元素的数组
- this.buttonArr = [];
- //全局变量/保存按钮元素的宽
- this.buttonWidth = {};
- //全局变量/保存播放器上新增元件的数组
- this.elementArr = [];
- //全局变量/字幕内容
- this.track = [];
- //全局变量/字幕索引
- this.trackIndex = 0;
- //全局变量/当前显示的字幕内容
- this.nowTrackShow = {
- sn: ''
- };
- //全局变量/保存字幕元件数组
- this.trackElement = [];
- //全局变量/将视频转换为图片
- this.timerVCanvas = null;
- //全局变量/animate
- this.animateArray = [];
- //全局变量/保存animate的元件
- this.animateElementArray = [];
- //全局变量/保存需要在暂停时停止缓动的数组
- this.animatePauseArray = [];
- //全局变量/预览图片加载状态/0=没有加载,1=正在加载,2=加载完成
- this.previewStart = 0;
- //全局变量/预览图片容器
- this.previewDiv = null;
- //全局变量/预览框
- this.previewTop = null;
- //全局变量/预览框的宽
- this.previewWidth = 120;
- //全局变量/预览图片容器缓动函数
- this.previewTween = null;
- //全局变量/是否是m3u8格式,是的话则可以加载hls.js
- this.isM3u8 = false;
- //全局变量/保存提示点数组
- this.promptArr = [];
- //全局变量/显示提示点文件的容器
- this.promptElement = null;
- //配置文件函数
- this.ckplayerConfig = {};
- //控制栏是否显示
- this.showFace = true;
- //是否监听过h5的错误
- this.errorAdd = false;
- //是否发送了错误
- this.errorSend = false;
- //控制栏是否隐藏
- this.controlBarIsShow = true;
- //字体
- this.fontFamily = '"Microsoft YaHei"; YaHei; "\5FAE\8F6F\96C5\9ED1"; SimHei; "\9ED1\4F53";Arial';
- //记录第一次拖动进度按钮时的位置
- this.timeSliderLeftTemp = 0;
- if(obj) {
- this.embed(obj);
- }
- };
- ckplayer.prototype = {
- /*
- 主要函数部分开始
- 主接口函数:
- 调用播放器需初始化该函数
- */
- embed: function(c) {
- //c:Object:是调用接口传递的属性对象
- if(window.location.href.substr(0, 7) == 'file://') {
- alert('Please use the HTTP protocol to open the page');
- return;
- }
- if(c == undefined || !c) {
- this.eject(this.errorList[0]);
- return;
- }
- if(typeof(c) != 'object') {
- this.eject(this.errorList[1]);
- }
- this.vars = this.standardization(this.varsConfig, c);
- if(!this.vars['mobileCkControls'] && this.isMobile()) {
- this.vars['flashplayer'] = false;
- this.showFace = false;
- }
- var videoString = this.vars['video'];
- if(!videoString) {
- this.eject(this.errorList[2]);
- return;
- }
- if(typeof(videoString) == 'string') {
- if(videoString.substr(0, 3) == 'CK:' || videoString.substr(0, 3) == 'CE:' || videoString.substr(8, 3) == 'CK:' || videoString.substr(8, 3) == 'CE:') {
- this.vars['flashplayer'] = true;
- }
- }
- if(this.vars['config']) {
- this.ckplayerConfig = eval(this.vars['config'] + '()');
- } else {
- this.ckplayerConfig = ckplayerConfig();
- }
- if((!this.supportVideo() && this.vars['flashplayer'] != '') || (this.vars['flashplayer'] && this.uploadFlash()) || !this.isMsie()) {
- this.html5Video = false;
- this.getVideo();
- } else if(videoString) {
- //判断视频数据类型
- this.analysedVideoUrl(videoString);
- return this;
- } else {
- this.eject(this.errorList[2]);
- }
- },
- /*
- 内部函数
- 根据外部传递过来的video开始分析视频地址
- */
- analysedVideoUrl: function(video) {
- var i = 0,
- y = 0;
- var thisTemp = this;
- //定义全局变量VA:Array:视频列表(包括视频地址,类型,清晰度说明)
- this.VA = [];
- if(typeof(video) == 'string') { //如果是字符形式的则判断后缀进行填充
- if(video.substr(0, 8) != 'website:') {
- this.VA = [
- [video, '', '', 0]
- ];
- var fileExt = this.getFileExt(video);
- switch(fileExt) {
- case '.mp4':
- this.VA[0][1] = 'video/mp4';
- break;
- case '.ogg':
- this.VA[0][1] = 'video/ogg';
- break;
- case '.webm':
- this.VA[0][1] = 'video/webm';
- break;
- default:
- break;
- }
- this.getVideo();
- } else {
- if(this.html5Video) {
- var ajaxObj = {
- url: video.substr(8),
- success: function(data) {
- if(data) {
- thisTemp.analysedUrl(data);
- } else {
- thisTemp.eject(thisTemp.errorList[5]);
- this.VA = video;
- thisTemp.getVideo();
- }
- }
- };
- this.ajax(ajaxObj);
- } else {
- this.VA = video;
- this.getVideo();
- }
- }
- } else if(typeof(video) == 'object') { //对象或数组
- if(!this.isUndefined(typeof(video.length))) { //说明是数组
- if(!this.isUndefined(typeof(video[0].length))) { //说明是数组形式的数组
- this.VA = video;
- }
- this.getVideo();
- } else {
- /*
- 如果video格式是对象形式,则分二种
- 如果video对象里包含type,则直接播放
- */
- if(!this.isUndefined(video['type'])) {
- this.VA.push([video['file'], video['type'], '', 0]);
- this.getVideo();
- } else {
- this.eject(this.errorList[5]);
- }
- }
- } else {
- this.eject(this.errorList[4]);
- }
- },
- /*
- 对请求到的视频地址进行重新分析
- */
- analysedUrl: function(data) {
- this.vars = this.standardization(this.vars, data);
- if(!this.isUndefined(data['video'])) {
- this.vars['video'] = data['video'];
- }
- this.analysedVideoUrl(this.vars['video']);
- },
- /*
- 内部函数
- 检查浏览器支持的视频格式,如果是则将支持的视频格式重新分组给播放列表
- */
- getHtml5Video: function() {
- var va = this.VA;
- var nva = [];
- var mobile = false;
- var video = document.createElement('video');
- var codecs = function(type) {
- var cod = '';
- switch(type) {
- case 'video/mp4':
- cod = 'avc1.4D401E, mp4a.40.2';
- break;
- case 'video/ogg':
- cod = 'theora, vorbis';
- break;
- case 'video/webm':
- cod = 'vp8.0, vorbis';
- break;
- default:
- break;
- }
- return cod;
- };
- var supportType = function(vidType, codType) {
- if(!video.canPlayType) {
- this.html5Video = false;
- return;
- }
- var isSupp = video.canPlayType(vidType + ';codecs="' + codType + '"');
- if(isSupp == '') {
- return false
- }
- return true;
- };
- if(this.vars['flashplayer'] || !this.isMsie()) {
- this.html5Video = false;
- return;
- }
- if(this.isMobile()) {
- mobile = true;
- }
- for(var i = 0; i < va.length; i++) {
- var v = va[i];
- if(v) {
- if(v[1] != '' && !mobile && supportType(v[1], codecs(v[1])) && v[0].substr(0, 4) != 'rtmp') {
- nva.push(v);
- }
- if((this.getFileExt(v[0]) == '.m3u8' || this.vars['type']=='video/m3u8' || this.vars['type']=='m3u8' || v[1]=='video/m3u8' || v[1]=='m3u8') && this.vars['html5m3u8']) {
- this.isM3u8 = true;
- nva.push(v);
- }
- }
- }
- if(nva.length > 0) {
- this.VA = nva;
- } else {
- if(!mobile) {
- this.html5Video = false;
- }
- }
- },
- /*
- 内部函数
- 根据视频地址开始构建播放器
- */
- getVideo: function() {
- //如果存在字幕则加载
- if(this.V) { //如果播放器已存在,则认为是从newVideo函数发送过来的请求
- this.changeVideo();
- return;
- }
- if(this.vars['cktrack']) {
- this.loadTrack();
- }
- if(this.supportVideo() && !this.vars['flashplayer']) {
- this.getHtml5Video(); //判断浏览器支持的视频格式
- }
- var thisTemp = this;
- var v = this.vars;
- var src = '',
- source = '',
- poster = '',
- loop = '',
- autoplay = '',
- track = '';
- var video = v['video'];
- var i = 0;
- this.CD = this.getByElement(v['container']);
- volume = v['volume'];
- if(!this.CD) {
- this.eject(this.errorList[6], v['container']);
- return false;
- }
- //开始构建播放容器
- var playerID = 'ckplayer' + this.randomString();
- var playerDiv = document.createElement('div');
- playerDiv.className = playerID;
- this.V = undefined;
- this.CD.innerHTML = '';
- this.CD.appendChild(playerDiv);
- this.PD = this.getByElement(playerID); //PD:定义播放器容器对象全局变量
- this.css(this.CD, {
- backgroundColor: '#000000',
- overflow: 'hidden',
- position: 'relative'
- });
- this.css(this.PD, {
- backgroundColor: '#000000',
- width: '100%',
- height: '100%',
- fontFamily: this.fontFamily
- });
- if(this.html5Video) { //如果支持HTML5-VIDEO则默认使用HTML5-VIDEO播放器
- //禁止播放器容器上鼠标选择文本
- this.PD.onselectstart = this.PD.ondrag = function() {
- return false;
- };
- //播放容器构建完成并且设置好样式
- //构建播放器
- if(this.VA.length == 1) {
- src = ' src="' + decodeURIComponent(this.VA[0][0]) + '"';
- } else {
- var videoArr = this.VA.slice(0);
- videoArr = this.arrSort(videoArr);
- for(i = 0; i < videoArr.length; i++) {
- var type = '';
- var va = videoArr[i];
- if(va[1]) {
- type = ' type="' + va[1] + '"';
- if(type == ' type="video/m3u8"' || type == ' type="m3u8"') {
- type = '';
- }
- }
- source += '<source src="' + decodeURIComponent(va[0]) + '"' + type + '>';
- }
- }
- //分析视频地址结束
- if(v['autoplay']) {
- autoplay = ' autoplay="autoplay"';
- }
- if(v['poster']) {
- poster = ' poster="' + v['poster'] + '"';
- }
- if(v['loop']) {
- loop = ' loop="loop"';
- }
- if(v['seek'] > 0) {
- this.needSeek = v['seek'];
- }
- if(v['track'] != null && v['cktrack'] == null) {
- var trackArr = v['track'];
- var trackDefault = '';
- var defaultHave = false;
- for(i = 0; i < trackArr.length; i++) {
- var trackObj = trackArr[i];
- if(trackObj['default'] && !defaultHave) {
- trackDefault = ' default';
- defaultHave = true;
- } else {
- trackDefault = '';
- }
- track += '<track kind="' + trackObj['kind'] + '" src="' + trackObj['src'] + '" srclang="' + trackObj['srclang'] + '" label="' + trackObj['label'] + '"' + trackDefault + '>';
- }
- }
- var autoLoad = this.ckplayerConfig['config']['autoLoad'];
- var preload = '';
- if(!autoLoad) {
- preload = ' preload="meta"';
- }
- var vid = this.randomString();
- var controls = '';
- if(!this.showFace) {
- controls = ' controls="controls"';
- }
- var html = '';
- if(!this.isM3u8) {
- html = '<video id="' + vid + '"' + src + ' width="100%" height="100%"' + autoplay + poster + loop + preload + controls + ' x5-playsinline="" playsinline="" webkit-playsinline="true">' + source + track + '</video>';
- } else {
- html = '<video id="' + vid + '" width="100%" height="100%"' + poster + loop + preload + controls + ' x5-playsinline="" playsinline="" webkit-playsinline="true">' + track + '</video>';
- }
- this.PD.innerHTML = html;
- this.V = this.getByElement('#' + vid); //V:定义播放器对象全局变量
- if(this.vars['crossorigin']) {
- this.V.crossOrigin = this.vars['crossorigin'];
- }
- try {
- this.V.volume = volume; //定义音量
- if(this.playbackRateArr && this.vars['playbackrate'] > -1) {
- if(this.vars['playbackrate'] < this.playbackRateArr.length) {
- this.playbackRateDefault = this.vars['playbackrate'];
- }
- this.V.playbackRate = this.playbackRateArr[this.playbackRateDefault][0]; //定义倍速
- }
- } catch(error) {}
- this.css(this.V, {
- width: '100%',
- height: '100%'
- });
- if(this.isM3u8) {
- var loadJsHandler = function() {
- thisTemp.embedHls(thisTemp.VA[0][0], v['autoplay']);
- };
- this.loadJs(javascriptPath + 'hls/hls.min.js', loadJsHandler);
- }
- this.css(this.V, 'backgroundColor', '#000000');
- //创建一个画布容器
- if(this.config['videoDrawImage']) {
- var canvasID = 'vcanvas' + this.randomString();
- var canvasDiv = document.createElement('div');
- canvasDiv.className = canvasID;
- this.PD.appendChild(canvasDiv);
- this.MD = this.getByElement(canvasID); //定义画布存储容器
- this.css(this.MD, {
- backgroundColor: '#000000',
- width: '100%',
- height: '100%',
- position: 'absolute',
- display: 'none',
- cursor: 'pointer',
- left: '0px',
- top: '0px',
- zIndex: '10'
- });
- var cvid = 'ccanvas' + this.randomString();
- this.MD.innerHTML = this.newCanvas(cvid, this.PD.offsetWidth, this.PD.offsetHeight);
- this.MDC = this.getByElement(cvid + '-canvas');
- this.MDCX = this.MDC.getContext('2d');
- }
- this.playerType = 'html5video';
- //播放器构建完成并且设置好样式
- //建立播放器的监听函数,包含操作监听及事件监听
- this.addVEvent();
- //根据清晰度的值构建清晰度切换按钮
- if(this.showFace) {
- this.definition();
- if(!this.vars['live'] && this.playbackRateArr && this.vars['playbackrate'] > -1) {
- this.playbackRate();
- }
- if(v['autoplay']) {
- this.loadingStart(true);
- }
- }
- this.playerLoad();
- } else { //如果不支持HTML5-VIDEO则调用flashplayer
- this.embedSWF();
- }
- },
- /*
- 内部函数
- 发送播放器加载成功的消息
- */
- playerLoad: function() {
- var thisTemp = this;
- if(this.isFirst) {
- this.isFirst = false;
- window.setTimeout(function() {
- thisTemp.loadedHandler();
- }, 1);
- }
- },
- /*
- 内部函数
- 建立播放器的监听函数,包含操作监听及事件监听
- */
- addVEvent: function() {
- var thisTemp = this;
- //监听视频单击事件
- var eventVideoClick = function(event) {
- thisTemp.videoClick();
- };
- this.addListenerInside('click', eventVideoClick);
- this.addListenerInside('click', eventVideoClick, this.MDC);
- //延迟计算加载失败事件
- this.timerErrorFun();
- //监听视频加载到元数据事件
- var eventJudgeIsLive = function(event) {
- thisTemp.sendJS('loadedmetadata');
- thisTemp.sendJS('duration', thisTemp.V.duration);
- thisTemp.judgeIsLive();
- };
- this.addListenerInside('loadedmetadata', eventJudgeIsLive);
- //监听视频播放事件
- var eventPlaying = function(event) {
- thisTemp.playingHandler();
- thisTemp.sendJS('play');
- thisTemp.sendJS('paused', false);
- };
- this.addListenerInside('playing', eventPlaying);
- //监听视频暂停事件
- var eventPause = function(event) {
- thisTemp.pauseHandler();
- thisTemp.sendJS('pause');
- thisTemp.sendJS('paused', true);
- };
- this.addListenerInside('pause', eventPause);
- //监听视频播放时间事件
- var eventTimeupdate = function(event) {
- if(thisTemp.timerLoading != null) {
- thisTemp.loadingStart(false);
- }
- if(thisTemp.time) {
- thisTemp.sendJS('time', thisTemp.time);
- }
- };
- this.addListenerInside('timeupdate', eventTimeupdate);
- //监听视频缓冲事件
- var eventWaiting = function(event) {
- thisTemp.loadingStart(true);
- };
- this.addListenerInside('waiting', eventWaiting);
- //监听视频seek开始事件
- var eventSeeking = function(event) {
- thisTemp.sendJS('seek', 'start');
- };
- this.addListenerInside('seeking', eventSeeking);
- //监听视频seek结束事件
- var eventSeeked = function(event) {
- thisTemp.seekedHandler();
- thisTemp.sendJS('seek', 'ended');
- };
- this.addListenerInside('seeked', eventSeeked);
- //监听视频播放结束事件
- var eventEnded = function(event) {
- thisTemp.endedHandler();
- thisTemp.sendJS('ended');
- };
- this.addListenerInside('ended', eventEnded);
- //监听视频音量
- var eventVolumeChange = function(event) {
- try {
- thisTemp.volumechangeHandler();
- thisTemp.sendJS('volume', thisTemp.volume || thisTemp.V.volume);
- } catch(event) {}
- };
- this.addListenerInside('volumechange', eventVolumeChange);
- //监听全屏事件
- var eventFullChange = function(event) {
- var fullState = document.fullScreen || document.mozFullScreen || document.webkitIsFullScreen;
- thisTemp.sendJS('full', fullState);
- };
- this.addListenerInside('fullscreenchange', eventFullChange);
- this.addListenerInside('webkitfullscreenchange', eventFullChange);
- this.addListenerInside('mozfullscreenchange', eventFullChange);
- //建立界面
- if(this.showFace) {
- this.interFace();
- }
- },
- /*
- 内部函数
- 重置界面元素
- */
- resetPlayer: function() {
- this.timeTextHandler();
- if(this.showFace) {
- this.timeProgress(0, 1); //改变时间进度条宽
- this.changeLoad(0);
- this.initPlayPause(); //判断显示播放或暂停按钮
- this.definition(); //构建清晰度按钮
- this.showFrontNext(); //构建上一集下一集按钮
- this.deletePrompt(); //删除提示点
- this.deletePreview(); //删除预览图
- this.trackHide(); //重置字幕
- this.resetTrack();
- this.trackElement = [];
- this.track = [];
- }
- },
- /*
- 内部函数
- 构建界面元素
- */
- interFace: function() {
- this.showFace = true;
- var thisTemp = this;
- var html = ''; //控制栏内容
- var i = 0;
- var bWidth = 38, //按钮的宽
- bHeight = 38; //按钮的高
- var bBgColor = '#FFFFFF', //按钮元素默认颜色
- bOverColor = '#0782F5'; //按钮元素鼠标经过时的颜色
- var timeInto = this.formatTime(0) + ' / ' + this.formatTime(this.vars['duration']); //时间显示框默认显示内容
- var randomS = this.randomString(10); //获取一个随机字符串
- /*
- 以下定义界面各元素的ID,统一以ID结束
- */
- var controlBarBgID = 'controlbgbar' + randomS, //控制栏背景
- controlBarID = 'controlbar' + randomS, //控制栏容器
- timeProgressBgID = 'timeprogressbg' + randomS, //播放进度条背景
- loadProgressID = 'loadprogress' + randomS, //加载进度条
- timeProgressID = 'timeprogress' + randomS, //播放进度条
- timeBOBGID = 'timebobg' + randomS, //播放进度按钮容器,该元素为一个透明覆盖在播放进度条上
- timeBOID = 'timebo' + randomS, //播放进度可拖动按钮外框
- timeBWID = 'timebw' + randomS, //播放进度可拖动按钮内框
- timeTextID = 'timetext' + randomS, //时间文本框
- playID = 'play' + randomS, //播放按钮
- pauseID = 'pause' + randomS, //暂停按钮
- frontID = 'front' + randomS, //前一集按钮
- nextID = 'next' + randomS, //下一集按钮
- fullID = 'full' + randomS, //全屏按钮
- escFullID = 'escfull' + randomS, //退出全屏按钮
- muteID = 'mute' + randomS, //静音按钮
- escMuteID = 'escmute' + randomS, //取消静音按钮
- volumeID = 'volume' + randomS, //音量调节框容器
- volumeDbgID = 'volumedbg' + randomS, //音量调节框容器背景
- volumeBgID = 'volumebg' + randomS, //音量调节框背景层
- volumeUpID = 'volumeup' + randomS, //音量调节框可变宽度层
- volumeBOID = 'volumebo' + randomS, //音量调节按钮外框
- volumeBWID = 'volumebw' + randomS, //音量调节按钮内框
- definitionID = 'definition' + randomS, //清晰度容器
- definitionPID = 'definitionp' + randomS, //清晰度列表容器
- playbackRateID = 'playbackrate' + randomS, //清晰度容器
- playbackRatePID = 'playbackratep' + randomS, //清晰度列表容器
- promptBgID = 'promptbg' + randomS, //提示框背景
- promptID = 'prompt' + randomS, //提示框
- dlineID = 'dline' + randomS, //分隔线共用前缀
- menuID = 'menu' + randomS, //右键容器
- pauseCenterID = 'pausecenter' + randomS, //中间暂停按钮
- loadingID = 'loading' + randomS, //缓冲
- errorTextID = 'errortext' + randomS, //错误文本框
- logoID = 'logo' + randomS; //logo
- //构建一些PD(播放器容器)里使用的元素
- var controlBarBg = document.createElement('div'),
- controlBar = document.createElement('div'),
- timeProgressBg = document.createElement('div'),
- timeBoBg = document.createElement('div'),
- pauseCenter = document.createElement('div'),
- errorText = document.createElement('div'),
- promptBg = document.createElement('div'),
- prompt = document.createElement('div'),
- menuDiv = document.createElement('div'),
- definitionP = document.createElement('div'),
- playbackrateP = document.createElement('div'),
- loading = document.createElement('div'),
- logo = document.createElement('div');
- controlBarBg.className = controlBarBgID;
- controlBar.className = controlBarID;
- timeProgressBg.className = timeProgressBgID;
- timeBoBg.className = timeBOBGID;
- promptBg.className = promptBgID;
- prompt.className = promptID;
- menuDiv.className = menuID;
- definitionP.className = definitionPID;
- playbackrateP.className = playbackRatePID;
- pauseCenter.className = pauseCenterID;
- loading.className = loadingID;
- logo.className = logoID;
- errorText.className = errorTextID;
- this.PD.appendChild(controlBarBg);
- this.PD.appendChild(controlBar);
- this.PD.appendChild(timeProgressBg);
- this.PD.appendChild(timeBoBg);
- this.PD.appendChild(promptBg);
- this.PD.appendChild(prompt);
- this.PD.appendChild(definitionP);
- this.PD.appendChild(playbackrateP);
- this.PD.appendChild(pauseCenter);
- this.PD.appendChild(loading);
- this.PD.appendChild(errorText);
- this.PD.appendChild(logo);
- this.body.appendChild(menuDiv);
- //构建一些PD(播放器容器)里使用的元素结束
- if(this.vars['live']) { //如果是直播,时间显示文本框里显示当前系统时间
- timeInto = this.getNowDate();
- }
- //构建控制栏的内容
- html += '<div class="' + playID + '" data-title="' + thisTemp.language['play'] + '">' + this.newCanvas(playID, bWidth, bHeight) + '</div>'; //播放按钮
- html += '<div class="' + pauseID + '" data-title="' + thisTemp.language['pause'] + '">' + this.newCanvas(pauseID, bWidth, bHeight) + '</div>'; //暂停按钮
- html += '<div class="' + dlineID + '-la"></div>'; //分隔线
- html += '<div class="' + frontID + '" data-title="' + thisTemp.language['front'] + '">' + this.newCanvas(frontID, bWidth, bHeight) + '</div>'; //前一集按钮
- html += '<div class="' + dlineID + '-lb"></div>'; //分隔线
- html += '<div class="' + nextID + '" data-title="' + thisTemp.language['next'] + '">' + this.newCanvas(nextID, bWidth, bHeight) + '</div>'; //下一集按钮
- html += '<div class="' + dlineID + '-lc"></div>'; //分隔线
- html += '<div class="' + timeTextID + '">' + timeInto + '</div>'; //时间文本
- html += '<div class="' + fullID + '" data-title="' + thisTemp.language['full'] + '">' + this.newCanvas(fullID, bWidth, bHeight) + '</div>'; //全屏按钮
- html += '<div class="' + escFullID + '" data-title="' + thisTemp.language['escFull'] + '">' + this.newCanvas(escFullID, bWidth, bHeight) + '</div>'; //退出全屏按钮
- html += '<div class="' + dlineID + '-ra"></div>'; //分隔线
- html += '<div class="' + definitionID + '" data-title="' + thisTemp.language['definition'] + '"></div>'; //清晰度容器
- html += '<div class="' + dlineID + '-rb"></div>'; //分隔线
- html += '<div class="' + playbackRateID + '" data-title="' + thisTemp.language['playbackRate'] + '"></div>'; //倍速
- html += '<div class="' + dlineID + '-rc"></div>'; //分隔线
- html += '<div class="' + volumeID + '"><div class="' + volumeDbgID + '"><div class="' + volumeBgID + '"><div class="' + volumeUpID + '"></div></div><div class="' + volumeBOID + '"><div class="' + volumeBWID + '"></div></div></div></div>'; //音量调节框,音量调节按钮
- html += '<div class="' + muteID + '" data-title="' + thisTemp.language['mute'] + '">' + this.newCanvas(muteID, bWidth, bHeight) + '</div>'; //静音按钮
- html += '<div class="' + escMuteID + '" data-title="' + thisTemp.language['escMute'] + '">' + this.newCanvas(escMuteID, bWidth, bHeight) + '</div>'; //退出静音按钮
- html += '<div class="' + dlineID + '-rd"></div>'; //分隔线
- this.getByElement(controlBarID).innerHTML = html;
- //构建控制栏内容结束
- //构建进度条内容
- this.getByElement(timeProgressBgID).innerHTML = '<div class="' + loadProgressID + '"></div><div class="' + timeProgressID + '"></div>';
- this.getByElement(timeBOBGID).innerHTML = '<div class="' + timeBOID + '"><div class="' + timeBWID + '"></div></div>';
- //构建进度条内容结束
- this.getByElement(pauseCenterID).innerHTML = this.newCanvas(pauseCenterID, 80, 80); //构建中间暂停按钮
- this.getByElement(loadingID).innerHTML = this.newCanvas(loadingID, 60, 60); //构建中间缓冲时显示的图标
- this.getByElement(errorTextID).innerHTML = this.language['error']; //构建错误时显示的文本框
- if(this.ckplayerConfig['style']['logo']) {
- if(this.ckplayerConfig['style']['logo']['file']) {
- var logoFile = this.ckplayerConfig['style']['logo']['file'];
- if(logoFile.substr(0, 15) == 'data:image/png;' || logoFile.substr(0, 15) == 'data:image/jpg;' || logoFile.substr(0, 15) == 'data:image/jpeg;') {
- this.getByElement(logoID).innerHTML = '<img src="' + logoFile + '" border="0">'; //构建logo
- }
- }
- } else {
- this.getByElement(logoID).innerHTML = this.vars['logo'] || this.logo || ''; //构建logo
- }
- //CB:Object:全局变量,将一些全局需要用到的元素统一放在CB对象里
- var pd = this.PD;
- this.CB = {
- controlBarBg: this.getByElement(controlBarBgID, pd),
- controlBar: this.getByElement(controlBarID, pd),
- promptBg: this.getByElement(promptBgID, pd),
- prompt: this.getByElement(promptID, pd),
- timeProgressBg: this.getByElement(timeProgressBgID, pd),
- loadProgress: this.getByElement(loadProgressID, pd),
- timeProgress: this.getByElement(timeProgressID, pd),
- timeBoBg: this.getByElement(timeBOBGID, pd),
- timeButton: this.getByElement(timeBOID, pd),
- timeText: this.getByElement(timeTextID, pd),
- play: this.getByElement(playID, pd),
- front: this.getByElement(frontID, pd),
- next: this.getByElement(nextID, pd),
- pause: this.getByElement(pauseID, pd),
- definition: this.getByElement(definitionID, pd),
- definitionP: this.getByElement(definitionPID, pd),
- definitionLine: this.getByElement(dlineID + '-rb', pd),
- playbackrate: this.getByElement(playbackRateID, pd),
- playbackrateP: this.getByElement(playbackRatePID, pd),
- playbackrateLine: this.getByElement(dlineID + '-rc', pd),
- full: this.getByElement(fullID, pd),
- escFull: this.getByElement(escFullID, pd),
- mute: this.getByElement(muteID, pd),
- escMute: this.getByElement(escMuteID, pd),
- volume: this.getByElement(volumeID, pd),
- volumeBg: this.getByElement(volumeBgID, pd),
- volumeUp: this.getByElement(volumeUpID, pd),
- volumeBO: this.getByElement(volumeBOID, pd),
- pauseCenter: this.getByElement(pauseCenterID, pd),
- menu: this.getByElement(menuID),
- loading: this.getByElement(loadingID, pd),
- loadingCanvas: this.getByElement(loadingID + '-canvas', pd),
- errorText: this.getByElement(errorTextID, pd),
- logo: this.getByElement(logoID, pd),
- playLine: this.getByElement(dlineID + '-la', pd),
- frontLine: this.getByElement(dlineID + '-lb', pd),
- nextLine: this.getByElement(dlineID + '-lc', pd),
- fullLine: this.getByElement(dlineID + '-ra'),
- definitionLine: this.getByElement(dlineID + '-rb', pd),
- muteLine: this.getByElement(dlineID + '-rd', pd)
- };
- this.buttonWidth = {
- play: bWidth,
- full: bWidth,
- front: bWidth,
- next: bWidth,
- mute: bWidth
- };
- //定义界面元素的样式
- //控制栏背景
- this.css(controlBarBgID, {
- width: '100%',
- height: bHeight + 'px',
- backgroundColor: '#000000',
- position: 'absolute',
- bottom: '0px',
- filter: 'alpha(opacity:0.8)',
- opacity: '0.8',
- zIndex: '90'
- });
- //控制栏容器
- this.css(controlBarID, {
- width: '100%',
- height: bHeight + 'px',
- position: 'absolute',
- bottom: '0px',
- zIndex: '90'
- });
- //中间暂停按钮
- this.css(pauseCenterID, {
- width: '80px',
- height: '80px',
- borderRadius: '50%',
- position: 'absolute',
- display: 'none',
- cursor: 'pointer',
- zIndex: '100'
- });
- //loading
- this.css(loadingID, {
- width: '60px',
- height: '60px',
- position: 'absolute',
- display: 'none',
- zIndex: '100'
- });
- //出错文本框
- this.css(errorTextID, {
- width: '120px',
- height: '30px',
- lineHeight: '30px',
- color: '#FFFFFF',
- fontSize: '14px',
- textAlign: 'center',
- position: 'absolute',
- display: 'none',
- zIndex: '101',
- cursor: 'default',
- zIndex: '100'
- });
- //定义logo文字的样式
- this.css(logoID, {
- height: '30px',
- lineHeight: '30px',
- color: '#FFFFFF',
- fontFamily: 'Arial',
- fontSize: '28px',
- textAlign: 'center',
- position: 'absolute',
- float: 'left',
- left: '-1000px',
- top: '20px',
- zIndex: '100',
- filter: 'alpha(opacity:0.8)',
- opacity: '0.8',
- cursor: 'default'
- });
- this.css(this.CB['loadingCanvas'], {
- transform: 'rotate(0deg)',
- msTransform: 'rotate(0deg)',
- mozTransform: 'rotate(0deg)',
- webkitTransform: 'rotate(0deg)',
- oTransform: 'rotate(0deg)'
- });
- //定义提示语的样式
- this.css([promptBgID, promptID], {
- height: '30px',
- lineHeight: '30px',
- color: '#FFFFFF',
- fontSize: '14px',
- textAlign: 'center',
- position: 'absolute',
- borderRadius: '5px',
- paddingLeft: '5px',
- paddingRight: '5px',
- bottom: '0px',
- display: 'none',
- zIndex: '95'
- });
- this.css(promptBgID, {
- backgroundColor: '#000000',
- filter: 'alpha(opacity:0.5)',
- opacity: '0.5'
- });
- //时间进度条背景容器
- this.css(timeProgressBgID, {
- width: '100%',
- height: '6px',
- backgroundColor: '#3F3F3F',
- overflow: 'hidden',
- position: 'absolute',
- bottom: '38px',
- zIndex: '88'
- });
- //加载进度和时间进度
- this.css([loadProgressID, timeProgressID], {
- width: '1px',
- height: '6px',
- position: 'absolute',
- bottom: '38px',
- top: '0px',
- zIndex: '91'
- });
- this.css(loadProgressID, 'backgroundColor', '#6F6F6F');
- this.css(timeProgressID, 'backgroundColor', bOverColor);
- //时间进度按钮
- this.css(timeBOBGID, {
- width: '100%',
- height: '14px',
- overflow: 'hidden',
- position: 'absolute',
- bottom: '34px',
- cursor: 'pointer',
- zIndex: '92'
- });
- this.css(timeBOID, {
- width: '14px',
- height: '14px',
- overflow: 'hidden',
- borderRadius: '50%',
- backgroundColor: bBgColor,
- cursor: 'pointer',
- position: 'absolute',
- top: '0px',
- zIndex: '20'
- });
- this.css(timeBWID, {
- width: '8px',
- height: '8px',
- overflow: 'hidden',
- borderRadius: '50%',
- position: 'absolute',
- backgroundColor: bOverColor,
- left: '3px',
- top: '3px'
- });
- this.css(timeTextID, {
- lineHeight: bHeight + 'px',
- color: '#FFFFFF',
- fontFamily: 'arial',
- fontSize: '16px',
- paddingLeft: '10px',
- float: 'left',
- overflow: 'hidden',
- cursor: 'default'
- });
- //分隔线
- this.css([dlineID + '-la', dlineID + '-lb', dlineID + '-lc', dlineID + '-ra', dlineID + '-rb', dlineID + '-rc', dlineID + '-rd'], {
- width: '0px',
- height: bHeight + 'px',
- overflow: 'hidden',
- borderLeft: '1px solid #303030',
- borderRight: '1px solid #151515',
- filter: 'alpha(opacity:0.9)',
- opacity: '0.9'
- });
- this.css([dlineID + '-la', dlineID + '-lb', dlineID + '-lc'], 'float', 'left');
- this.css([dlineID + '-ra', dlineID + '-rb', dlineID + '-rc', dlineID + '-rd'], 'float', 'right');
- this.css([dlineID + '-lb', dlineID + '-lc', dlineID + '-rb', dlineID + '-rc'], 'display', 'none');
- //播放/暂停/上一集/下一集按钮
- this.css([playID, pauseID, frontID, nextID], {
- width: bWidth + 'px',
- height: bHeight + 'px',
- float: 'left',
- overflow: 'hidden',
- cursor: 'pointer'
- });
- this.css([frontID, nextID], 'display', 'none');
- //初始化判断播放/暂停按钮隐藏项
- this.initPlayPause();
- //设置静音/取消静音的按钮样式
- this.css([muteID, escMuteID], {
- width: bWidth + 'px',
- height: bHeight + 'px',
- float: 'right',
- overflow: 'hidden',
- cursor: 'pointer'
- });
- if(this.vars['volume'] > 0) {
- this.css(escMuteID, 'display', 'none');
- } else {
- this.css(muteID, 'display', 'none');
- }
- //音量调节框
- this.css([volumeID, volumeDbgID], {
- width: '110px',
- height: bHeight + 'px',
- overflow: 'hidden',
- float: 'right'
- });
- this.css(volumeDbgID, {
- position: 'absolute'
- });
- this.css([volumeBgID, volumeUpID], {
- width: '100px',
- height: '6px',
- overflow: 'hidden',
- borderRadius: '5px',
- cursor: 'pointer'
- });
- this.css(volumeBgID, {
- position: 'absolute',
- top: '16px'
- });
- this.css(volumeBgID, 'backgroundColor', '#666666');
- this.css(volumeUpID, 'backgroundColor', bOverColor);
- this.buttonWidth['volume'] = 100;
- //音量调节按钮
- this.css(volumeBOID, {
- width: '12px',
- height: '12px',
- overflow: 'hidden',
- borderRadius: '50%',
- position: 'absolute',
- backgroundColor: bBgColor,
- top: '13px',
- left: '0px',
- cursor: 'pointer'
- });
- this.css(volumeBWID, {
- width: '6px',
- height: '6px',
- overflow: 'hidden',
- borderRadius: '50%',
- position: 'absolute',
- backgroundColor: bOverColor,
- left: '3px',
- top: '3px'
- });
- //清晰度容器
- this.css(definitionID, {
- lineHeight: bHeight + 'px',
- color: '#FFFFFF',
- float: 'right',
- fontSize: '14px',
- textAlign: 'center',
- overflow: 'hidden',
- display: 'none',
- cursor: 'pointer'
- });
- this.css(definitionPID, {
- lineHeight: (bHeight - 8) + 'px',
- color: '#FFFFFF',
- overflow: 'hidden',
- position: 'absolute',
- bottom: '4px',
- backgroundColor: '#000000',
- textAlign: 'center',
- zIndex: '95',
- cursor: 'pointer',
- display: 'none'
- });
- //倍速容器
- this.css(playbackRateID, {
- lineHeight: bHeight + 'px',
- color: '#FFFFFF',
- float: 'right',
- fontSize: '14px',
- textAlign: 'center',
- overflow: 'hidden',
- display: 'none',
- cursor: 'pointer'
- });
- this.css(playbackRatePID, {
- lineHeight: (bHeight - 8) + 'px',
- color: '#FFFFFF',
- overflow: 'hidden',
- position: 'absolute',
- bottom: '4px',
- backgroundColor: '#000000',
- textAlign: 'center',
- zIndex: '95',
- cursor: 'pointer',
- display: 'none'
- });
- //设置全屏/退出全屏按钮样式
- this.css([fullID, escFullID], {
- width: bWidth + 'px',
- height: bHeight + 'px',
- float: 'right',
- overflow: 'hidden',
- cursor: 'pointer'
- });
- this.css(escFullID, 'display', 'none');
- //构建各按钮的形状
- //播放按钮
- var cPlay = this.getByElement(playID + '-canvas').getContext('2d');
- var cPlayFillRect = function() {
- thisTemp.canvasFill(cPlay, [
- [12, 10],
- [29, 19],
- [12, 28]
- ]);
- };
- cPlay.fillStyle = bBgColor;
- cPlayFillRect();
- var cPlayOver = function(event) {
- cPlay.clearRect(0, 0, bWidth, bHeight);
- cPlay.fillStyle = bOverColor;
- cPlayFillRect();
- };
- var cPlayOut = function(event) {
- cPlay.clearRect(0, 0, bWidth, bHeight);
- cPlay.fillStyle = bBgColor;
- cPlayFillRect();
- };
- this.addListenerInside('mouseover', cPlayOver, this.getByElement(playID + '-canvas'));
- this.addListenerInside('mouseout', cPlayOut, this.getByElement(playID + '-canvas'));
- //暂停按钮
- var cPause = this.getByElement(pauseID + '-canvas').getContext('2d');
- var cPauseFillRect = function() {
- thisTemp.canvasFillRect(cPause, [
- [10, 10, 5, 18],
- [22, 10, 5, 18]
- ]);
- };
- cPause.fillStyle = bBgColor;
- cPauseFillRect();
- var cPauseOver = function(event) {
- cPause.clearRect(0, 0, bWidth, bHeight);
- cPause.fillStyle = bOverColor;
- cPauseFillRect();
- };
- var cPauseOut = function(event) {
- cPause.clearRect(0, 0, bWidth, bHeight);
- cPause.fillStyle = bBgColor;
- cPauseFillRect();
- };
- this.addListenerInside('mouseover', cPauseOver, this.getByElement(pauseID + '-canvas'));
- this.addListenerInside('mouseout', cPauseOut, this.getByElement(pauseID + '-canvas'));
- //前一集按钮
- var cFront = this.getByElement(frontID + '-canvas').getContext('2d');
- var cFrontFillRect = function() {
- thisTemp.canvasFill(cFront, [
- [16, 19],
- [30, 10],
- [30, 28]
- ]);
- thisTemp.canvasFillRect(cFront, [
- [8, 10, 5, 18]
- ]);
- };
- cFront.fillStyle = bBgColor;
- cFrontFillRect();
- var cFrontOver = function(event) {
- cFront.clearRect(0, 0, bWidth, bHeight);
- cFront.fillStyle = bOverColor;
- cFrontFillRect();
- };
- var cFrontOut = function(event) {
- cFront.clearRect(0, 0, bWidth, bHeight);
- cFront.fillStyle = bBgColor;
- cFrontFillRect();
- };
- this.addListenerInside('mouseover', cFrontOver, this.getByElement(frontID + '-canvas'));
- this.addListenerInside('mouseout', cFrontOut, this.getByElement(frontID + '-canvas'));
- //下一集按钮
- var cNext = this.getByElement(nextID + '-canvas').getContext('2d');
- var cNextFillRect = function() {
- thisTemp.canvasFill(cNext, [
- [8, 10],
- [22, 19],
- [8, 28]
- ]);
- thisTemp.canvasFillRect(cNext, [
- [25, 10, 5, 18]
- ]);
- };
- cNext.fillStyle = bBgColor;
- cNextFillRect();
- var cNextOver = function(event) {
- cNext.clearRect(0, 0, bWidth, bHeight);
- cNext.fillStyle = bOverColor;
- cNextFillRect();
- };
- var cNextOut = function(event) {
- cNext.clearRect(0, 0, bWidth, bHeight);
- cNext.fillStyle = bBgColor;
- cNextFillRect();
- };
- this.addListenerInside('mouseover', cNextOver, this.getByElement(nextID + '-canvas'));
- this.addListenerInside('mouseout', cNextOut, this.getByElement(nextID + '-canvas'));
- //全屏按钮
- var cFull = this.getByElement(fullID + '-canvas').getContext('2d');
- var cFullFillRect = function() {
- thisTemp.canvasFillRect(cFull, [
- [19, 10, 9, 3],
- [25, 13, 3, 6],
- [10, 19, 3, 9],
- [13, 25, 6, 3]
- ]);
- };
- cFull.fillStyle = bBgColor;
- cFullFillRect();
- var cFullOver = function() {
- cFull.clearRect(0, 0, bWidth, bHeight);
- cFull.fillStyle = bOverColor;
- cFullFillRect();
- };
- var cFullOut = function() {
- cFull.clearRect(0, 0, bWidth, bHeight);
- cFull.fillStyle = bBgColor;
- cFullFillRect();
- };
- this.addListenerInside('mouseover', cFullOver, this.getByElement(fullID + '-canvas'));
- this.addListenerInside('mouseout', cFullOut, this.getByElement(fullID + '-canvas'));
- //定义退出全屏按钮样式
- var cEscFull = this.getByElement(escFullID + '-canvas').getContext('2d');
- var cEscFullFillRect = function() {
- thisTemp.canvasFillRect(cEscFull, [
- [20, 9, 3, 9],
- [23, 15, 6, 3],
- [9, 20, 9, 3],
- [15, 23, 3, 6]
- ]);
- };
- cEscFull.fillStyle = bBgColor;
- cEscFullFillRect();
- var cEscFullOver = function() {
- cEscFull.clearRect(0, 0, bWidth, bHeight);
- cEscFull.fillStyle = bOverColor;
- cEscFullFillRect();
- };
- var cEscFullOut = function() {
- cEscFull.clearRect(0, 0, bWidth, bHeight);
- cEscFull.fillStyle = bBgColor;
- cEscFullFillRect();
- };
- this.addListenerInside('mouseover', cEscFullOver, this.getByElement(escFullID + '-canvas'));
- this.addListenerInside('mouseout', cEscFullOut, this.getByElement(escFullID + '-canvas'));
- //定义全屏按钮的样式
- var cMute = this.getByElement(muteID + '-canvas').getContext('2d');
- var cMuteFillRect = function() {
- thisTemp.canvasFill(cMute, [
- [10, 15],
- [15, 15],
- [21, 10],
- [21, 28],
- [15, 23],
- [10, 23]
- ]);
- thisTemp.canvasFillRect(cMute, [
- [23, 15, 2, 8],
- [27, 10, 2, 18]
- ]);
- };
- cMute.fillStyle = bBgColor;
- cMuteFillRect();
- var cMuteOver = function() {
- cMute.clearRect(0, 0, bWidth, bHeight);
- cMute.fillStyle = bOverColor;
- cMuteFillRect();
- };
- var cMuteOut = function() {
- cMute.clearRect(0, 0, bWidth, bHeight);
- cMute.fillStyle = bBgColor;
- cMuteFillRect();
- };
- this.addListenerInside('mouseover', cMuteOver, this.getByElement(muteID + '-canvas'));
- this.addListenerInside('mouseout', cMuteOut, this.getByElement(muteID + '-canvas'));
- //定义退出全屏按钮样式
- var cEscMute = this.getByElement(escMuteID + '-canvas').getContext('2d');
- var cEscMuteFillRect = function() {
- thisTemp.canvasFill(cEscMute, [
- [10, 15],
- [15, 15],
- [21, 10],
- [21, 28],
- [15, 23],
- [10, 23]
- ]);
- thisTemp.canvasFill(cEscMute, [
- [23, 13],
- [24, 13],
- [33, 25],
- [32, 25]
- ]);
- thisTemp.canvasFill(cEscMute, [
- [32, 13],
- [33, 13],
- [24, 25],
- [23, 25]
- ]);
- };
- cEscMute.fillStyle = bBgColor;
- cEscMuteFillRect();
- var cEscMuteOver = function() {
- cEscMute.clearRect(0, 0, bWidth, bHeight);
- cEscMute.fillStyle = bOverColor;
- cEscMuteFillRect();
- };
- var cEscMuteOut = function() {
- cEscMute.clearRect(0, 0, bWidth, bHeight);
- cEscMute.fillStyle = bBgColor;
- cEscMuteFillRect();
- };
- this.addListenerInside('mouseover', cEscMuteOver, this.getByElement(escMuteID + '-canvas'));
- this.addListenerInside('mouseout', cEscMuteOut, this.getByElement(escMuteID + '-canvas'));
- //定义loading样式
- var cLoading = this.getByElement(loadingID + '-canvas').getContext('2d');
- var cLoadingFillRect = function() {
- cLoading.save();
- var grad = cLoading.createLinearGradient(0, 0, 60, 60);
- grad.addColorStop(0, bBgColor);
- var grad2 = cLoading.createLinearGradient(0, 0, 80, 60);
- grad2.addColorStop(1, bOverColor);
- var grad3 = cLoading.createLinearGradient(0, 0, 80, 60);
- grad3.addColorStop(1, '#FF9900');
- var grad4 = cLoading.createLinearGradient(0, 0, 80, 60);
- grad4.addColorStop(1, '#CC3300');
- cLoading.strokeStyle = grad; //设置描边样式
- cLoading.lineWidth = 8; //设置线宽
- cLoading.beginPath(); //路径开始
- cLoading.arc(30, 30, 25, 0, 0.4 * Math.PI, false); //用于绘制圆弧context.arc(x坐标,y坐标,半径,起始角度,终止角度,顺时针/逆时针)
- cLoading.stroke(); //绘制
- cLoading.closePath(); //路径结束
- cLoading.beginPath(); //路径开始
- cLoading.strokeStyle = grad2; //设置描边样式
- cLoading.arc(30, 30, 25, 0.5 * Math.PI, 0.9 * Math.PI, false); //用于绘制圆弧context.arc(x坐标,y坐标,半径,起始角度,终止角度,顺时针/逆时针)
- cLoading.stroke(); //绘制
- cLoading.beginPath(); //路径开始
- cLoading.strokeStyle = grad3; //设置描边样式
- cLoading.arc(30, 30, 25, Math.PI, 1.4 * Math.PI, false); //用于绘制圆弧context.arc(x坐标,y坐标,半径,起始角度,终止角度,顺时针/逆时针)
- cLoading.stroke(); //绘制
- cLoading.beginPath(); //路径开始
- cLoading.strokeStyle = grad4; //设置描边样式
- cLoading.arc(30, 30, 25, 1.5 * Math.PI, 1.9 * Math.PI, false); //用于绘制圆弧context.arc(x坐标,y坐标,半径,起始角度,终止角度,顺时针/逆时针)
- cLoading.stroke(); //绘制
- cLoading.closePath(); //路径结束
- cLoading.restore();
- };
- cLoading.fillStyle = bBgColor;
- cLoadingFillRect();
- //定义中间暂停按钮的样式
- var cPauseCenter = this.getByElement(pauseCenterID + '-canvas').getContext('2d');
- var cPauseCenterFillRect = function() {
- thisTemp.canvasFill(cPauseCenter, [
- [28, 22],
- [59, 38],
- [28, 58]
- ]);
- /* 指定几个颜色 */
- cPauseCenter.save();
- cPauseCenter.lineWidth = 5; //设置线宽
- cPauseCenter.beginPath(); //路径开始
- cPauseCenter.arc(40, 40, 35, 0, 2 * Math.PI, false); //用于绘制圆弧context.arc(x坐标,y坐标,半径,起始角度,终止角度,顺时针/逆时针)
- cPauseCenter.stroke(); //绘制
- cPauseCenter.closePath(); //路径结束
- cPauseCenter.restore();
- };
- cPauseCenter.fillStyle = bBgColor;
- cPauseCenter.strokeStyle = bBgColor;
- cPauseCenterFillRect();
- var cPauseCenterOver = function() {
- cPauseCenter.clearRect(0, 0, 80, 80);
- cPauseCenter.fillStyle = bOverColor;
- cPauseCenter.strokeStyle = bOverColor;
- cPauseCenterFillRect();
- };
- var cPauseCenterOut = function() {
- cPauseCenter.clearRect(0, 0, 80, 80);
- cPauseCenter.fillStyle = bBgColor;
- cPauseCenter.strokeStyle = bBgColor;
- cPauseCenterFillRect();
- };
- this.addListenerInside('mouseover', cPauseCenterOver, this.getByElement(pauseCenterID + '-canvas'));
- this.addListenerInside('mouseout', cPauseCenterOut, this.getByElement(pauseCenterID + '-canvas'));
- //鼠标经过/离开音量调节按钮
- var volumeBOOver = function() {
- thisTemp.css(volumeBOID, 'backgroundColor', bOverColor);
- thisTemp.css(volumeBWID, 'backgroundColor', bBgColor);
- };
- var volumeBOOut = function() {
- thisTemp.css(volumeBOID, 'backgroundColor', bBgColor);
- thisTemp.css(volumeBWID, 'backgroundColor', bOverColor);
- };
- this.addListenerInside('mouseover', volumeBOOver, this.getByElement(volumeBOID));
- this.addListenerInside('mouseout', volumeBOOut, this.getByElement(volumeBOID));
- //鼠标经过/离开进度按钮
- var timeBOOver = function() {
- thisTemp.css(timeBOID, 'backgroundColor', bOverColor);
- thisTemp.css(timeBWID, 'backgroundColor', bBgColor);
- };
- var timeBOOut = function() {
- thisTemp.css(timeBOID, 'backgroundColor', bBgColor);
- thisTemp.css(timeBWID, 'backgroundColor', bOverColor);
- };
- this.addListenerInside('mouseover', timeBOOver, this.getByElement(timeBOID));
- this.addListenerInside('mouseout', timeBOOut, this.getByElement(timeBOID));
- this.addButtonEvent(); //注册按钮及音量调节,进度操作事件
- this.newMenu(); //单独设置右键的样式和事件
- this.controlBarHide(); //单独注册控制栏隐藏事件
- this.keypress(); //单独注册键盘事件
- //初始化音量调节框
- this.changeVolume(this.vars['volume']);
- //初始化判断是否需要显示上一集和下一集按钮
- this.showFrontNext();
- window.setTimeout(function() {
- thisTemp.elementCoordinate(); //调整中间暂停按钮/loading的位置/error的位置
- }, 100);
- this.checkBarWidth();
- var resize = function() {
- thisTemp.elementCoordinate();
- thisTemp.timeUpdateHandler();
- thisTemp.changeLoad();
- thisTemp.checkBarWidth();
- thisTemp.changeElementCoor(); //修改新加元件的坐标
- thisTemp.changePrompt();
- };
- this.addListenerInside('resize', resize, window);
- },
- /*
- 内部函数
- 创建按钮,使用canvas画布
- */
- newCanvas: function(id, width, height) {
- return '<canvas class="' + id + '-canvas" width="' + width + '" height="' + height + '"></canvas>';
- },
- /*
- 内部函数
- 注册按钮,音量调节框,进度操作框事件
- */
- addButtonEvent: function() {
- var thisTemp = this;
- //定义按钮的单击事件
- var playClick = function(event) {
- thisTemp.videoPlay();
- thisTemp.sendJS('clickEvent', 'actionScript->videoPlay');
- };
- this.addListenerInside('click', playClick, this.CB['play']);
- this.addListenerInside('click', playClick, this.CB['pauseCenter']);
- var pauseClick = function(event) {
- thisTemp.videoPause();
- thisTemp.sendJS('clickEvent', 'actionScript->videoPause');
- };
- this.addListenerInside('click', pauseClick, this.CB['pause']);
- var frontClick = function(event) {
- if(thisTemp.vars['front']) {
- eval(thisTemp.vars['front'] + '()');
- thisTemp.sendJS('clickEvent', 'actionScript->' + thisTemp.vars['front']);
- }
- };
- this.addListenerInside('click', frontClick, this.CB['front']);
- var nextClick = function(event) {
- if(thisTemp.vars['next']) {
- eval(thisTemp.vars['next'] + '()');
- thisTemp.sendJS('clickEvent', 'actionScript->' + thisTemp.vars['next']);
- }
- };
- this.addListenerInside('click', nextClick, this.CB['next']);
- var muteClick = function(event) {
- thisTemp.videoMute();
- thisTemp.sendJS('clickEvent', 'actionScript->videoMute');
- };
- this.addListenerInside('click', muteClick, this.CB['mute']);
- var escMuteClick = function(event) {
- thisTemp.videoEscMute();
- thisTemp.sendJS('clickEvent', 'actionScript->videoEscMute');
- };
- this.addListenerInside('click', escMuteClick, this.CB['escMute']);
- var fullClick = function(event) {
- thisTemp.fullScreen();
- thisTemp.sendJS('clickEvent', 'actionScript->fullScreen');
- };
- this.addListenerInside('click', fullClick, this.CB['full']);
- var escFullClick = function(event) {
- thisTemp.quitFullScreen();
- thisTemp.sendJS('clickEvent', 'actionScript->quitFullScreen');
- };
- this.addListenerInside('click', escFullClick, this.CB['escFull']);
- //定义各个按钮的鼠标经过/离开事件
- var promptHide = function(event) {
- thisTemp.promptShow(false);
- };
- var playOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['play']);
- };
- this.addListenerInside('mouseover', playOver, this.CB['play']);
- this.addListenerInside('mouseout', promptHide, this.CB['play']);
- var pauseOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['pause']);
- };
- this.addListenerInside('mouseover', pauseOver, this.CB['pause']);
- this.addListenerInside('mouseout', promptHide, this.CB['pause']);
- var frontOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['front']);
- };
- this.addListenerInside('mouseover', frontOver, this.CB['front']);
- this.addListenerInside('mouseout', promptHide, this.CB['front']);
- var nextOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['next']);
- };
- this.addListenerInside('mouseover', nextOver, this.CB['next']);
- this.addListenerInside('mouseout', promptHide, this.CB['next']);
- var muteOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['mute']);
- };
- this.addListenerInside('mouseover', muteOver, this.CB['mute']);
- this.addListenerInside('mouseout', promptHide, this.CB['mute']);
- var escMuteOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['escMute']);
- };
- this.addListenerInside('mouseover', escMuteOver, this.CB['escMute']);
- this.addListenerInside('mouseout', promptHide, this.CB['escMute']);
- var fullOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['full']);
- };
- this.addListenerInside('mouseover', fullOver, this.CB['full']);
- this.addListenerInside('mouseout', promptHide, this.CB['full']);
- var escFullOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['escFull']);
- };
- this.addListenerInside('mouseover', escFullOver, this.CB['escFull']);
- this.addListenerInside('mouseout', promptHide, this.CB['escFull']);
- var definitionOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['definition']);
- };
- this.addListenerInside('mouseover', definitionOver, this.CB['definition']);
- this.addListenerInside('mouseout', promptHide, this.CB['definition']);
- var playbackrateOver = function(event) {
- thisTemp.promptShow(thisTemp.CB['playbackrate']);
- };
- this.addListenerInside('mouseover', playbackrateOver, this.CB['playbackrate']);
- this.addListenerInside('mouseout', promptHide, this.CB['playbackrate']);
- //定义音量和进度按钮的滑块事件
- var volumePrompt = function(vol) {
- var volumeBOXY = thisTemp.getCoor(thisTemp.CB['volumeBO']);
- var promptObj = {
- title: thisTemp.language['volume'] + vol + '%',
- x: volumeBOXY['x'] + thisTemp.CB['volumeBO'].offsetWidth * 0.5,
- y: volumeBOXY['y']
- };
- thisTemp.promptShow(false, promptObj);
- };
- var volumeObj = {
- slider: this.CB['volumeBO'],
- follow: this.CB['volumeUp'],
- refer: this.CB['volumeBg'],
- grossValue: 'volume',
- pd: true,
- startFun: function(vol) {},
- monitorFun: function(vol) {
- thisTemp.changeVolume(vol * 0.01, false, false);
- volumePrompt(vol);
- },
- endFun: function(vol) {},
- overFun: function(vol) {
- volumePrompt(vol);
- }
- };
- this.slider(volumeObj);
- var volumeClickObj = {
- refer: this.CB['volumeBg'],
- grossValue: 'volume',
- fun: function(vol) {
- thisTemp.changeVolume(vol * 0.01, true, true);
- }
- };
- this.progressClick(volumeClickObj);
- this.timeButtonMouseDown(); //用单击的函数来判断是否需要建立控制栏监听
- //鼠标经过/离开音量调节框时的
- var volumeBgMove = function(event) {
- var volumeBgXY = thisTemp.getCoor(thisTemp.CB['volumeBg']);
- var eventX = thisTemp.client(event)['x'];
- var eventVolume = parseInt((eventX - volumeBgXY['x']) * 100 / thisTemp.CB['volumeBg'].offsetWidth);
- var buttonPromptObj = {
- title: thisTemp.language['volume'] + eventVolume + '%',
- x: eventX,
- y: volumeBgXY['y']
- };
- thisTemp.promptShow(false, buttonPromptObj);
- };
- this.addListenerInside('mousemove', volumeBgMove, this.CB['volumeBg']);
- this.addListenerInside('mouseout', promptHide, this.CB['volumeBg']);
- this.addListenerInside('mouseout', promptHide, this.CB['volumeBO']);
- //注册清晰度相关事件
- this.addDefListener();
- //注册倍速相关事件
- this.addPlaybackrate();
- },
- /*
- 内部函数
- 注册单击视频动作
- */
- videoClick: function() {
- var thisTemp = this;
- var clearTimerClick = function() {
- if(thisTemp.timerClick != null) {
- if(thisTemp.timerClick.runing) {
- thisTemp.timerClick.stop();
- }
- thisTemp.timerClick = null;
- }
- };
- var timerClickFun = function() {
- clearTimerClick();
- thisTemp.isClick = false;
- thisTemp.playOrPause();
- };
- clearTimerClick();
- if(this.isClick) {
- this.isClick = false;
- if(thisTemp.config['videoDbClick']) {
- if(!this.full) {
- thisTemp.fullScreen();
- } else {
- thisTemp.quitFullScreen();
- }
- }
- } else {
- this.isClick = true;
- this.timerClick = new this.timer(300, timerClickFun, 1)
- //this.timerClick.start();
- }
- },
- /*
- 内部函数
- 注册鼠标经过进度滑块的事件
- */
- timeButtonMouseDown: function() {
- var thisTemp = this;
- var timePrompt = function(time) {
- if(isNaN(time)) {
- time = 0;
- }
- var timeButtonXY = thisTemp.getCoor(thisTemp.CB['timeButton']);
- var promptObj = {
- title: thisTemp.formatTime(time),
- x: timeButtonXY['x'] - thisTemp.pdCoor['x'] + thisTemp.CB['timeButton'].offsetWidth * 0.5,
- y: timeButtonXY['y'] - thisTemp.pdCoor['y']
- };
- thisTemp.promptShow(false, promptObj);
- };
- var timeObj = {
- slider: this.CB['timeButton'],
- follow: this.CB['timeProgress'],
- refer: this.CB['timeBoBg'],
- grossValue: 'time',
- pd: false,
- startFun: function(time) {
- thisTemp.isTimeButtonMove = false;
- },
- monitorFun: function(time) {},
- endFun: function(time) {
- if(thisTemp.V) {
- if(thisTemp.V.duration > 0) {
- thisTemp.needSeek = 0;
- thisTemp.videoSeek(parseInt(time));
- }
- }
- },
- overFun: function(time) {
- timePrompt(time);
- }
- };
- var timeClickObj = {
- refer: this.CB['timeBoBg'],
- grossValue: 'time',
- fun: function(time) {
- if(thisTemp.V) {
- if(thisTemp.V.duration > 0) {
- thisTemp.needSeek = 0;
- thisTemp.videoSeek(parseInt(time));
- }
- }
- }
- };
- var timeBoBgmousemove = function(event) {
- var timeBoBgXY = thisTemp.getCoor(thisTemp.CB['timeBoBg']);
- var eventX = thisTemp.client(event)['x'];
- var eventTime = parseInt((eventX - timeBoBgXY['x']) * thisTemp.V.duration / thisTemp.CB['timeBoBg'].offsetWidth);
- var buttonPromptObj = {
- title: thisTemp.formatTime(eventTime),
- x: eventX,
- y: timeBoBgXY['y']
- };
- thisTemp.promptShow(false, buttonPromptObj);
- var def = false;
- if(!thisTemp.isUndefined(thisTemp.CB['definitionP'])) {
- if(thisTemp.css(thisTemp.CB['definitionP'], 'display') != 'block') {
- def = true;
- }
- }
- if(thisTemp.vars['preview'] != null && def) {
- buttonPromptObj['time'] = eventTime;
- thisTemp.preview(buttonPromptObj);
- }
- };
- var promptHide = function(event) {
- thisTemp.promptShow(false);
- if(thisTemp.previewDiv != null) {
- thisTemp.css([thisTemp.previewDiv, thisTemp.previewTop], 'display', 'none');
- }
- };
- if(!this.vars['live']) { //如果不是直播
- this.isTimeButtonDown = true;
- this.addListenerInside('mousemove', timeBoBgmousemove, this.CB['timeBoBg']);
- this.addListenerInside('mouseout', promptHide, this.CB['timeBoBg']);
- } else {
- this.isTimeButtonDown = false;
- timeObj['removeListenerInside'] = true;
- timeClickObj['removeListenerInside'] = true;
- }
- this.slider(timeObj);
- this.progressClick(timeClickObj);
- },
- /*
- 内部函数
- 注册调节框上单击事件,包含音量调节框和播放时度调节框
- */
- progressClick: function(obj) {
- /*
- refer:参考对象
- fun:返回函数
- refer:参考元素,即背景
- grossValue:调用的参考值类型
- pd:
- */
- //建立参考元素的mouseClick事件,用来做为鼠标在其上按下时触发的状态
- var thisTemp = this;
- var referMouseClick = function(event) {
- var referX = thisTemp.client(event)['x'] - thisTemp.getCoor(obj['refer'])['x'];
- var rWidth = obj['refer'].offsetWidth;
- var grossValue = 0;
- if(obj['grossValue'] == 'volume') {
- grossValue = 100;
- } else {
- if(thisTemp.V) {
- grossValue = thisTemp.V.duration;
- }
- }
- var nowZ = parseInt(referX * grossValue / rWidth);
- if(obj['fun']) {
- if(obj['grossValue'] === 'time') {
- var sliderXY = thisTemp.getCoor(thisTemp.CB['timeButton']);
- sliderLeft = sliderXY['x'];
- if(!thisTemp.checkSlideLeft(referX, sliderLeft, rWidth)) {
- return;
- }
- var bimeButtonWB = thisTemp.CB['timeButton'].offsetWidth * 0.5;
- thisTemp.css(thisTemp.CB['timeButton'], 'left', (referX - bimeButtonWB) + 'px');
- thisTemp.css(thisTemp.CB['timeProgress'], 'width', (referX) + 'px');
- }
- obj['fun'](nowZ);
- }
- };
- if(this.isUndefined(obj['removeListenerInside'])) {
- this.addListenerInside('click', referMouseClick, obj['refer']);
- } else {
- this.removeListenerInside('click', referMouseClick, obj['refer']);
- }
- },
- /*
- 内部函数
- 共用的注册滑块事件
- */
- slider: function(obj) {
- /*
- obj={
- slider:滑块元素
- follow:跟随滑块的元素
- refer:参考元素,即背景
- grossValue:调用的参考值类型
- startFun:开始调用的元素
- monitorFun:监听函数
- endFun:结束调用的函数
- overFun:鼠标放上去后调用的函数
- pd:是否需要修正
- }
- */
- var thisTemp = this;
- var clientX = 0,
- criterionWidth = 0,
- sliderLeft = 0,
- referLeft = 0;
- var value = 0;
- var calculation = function() { //根据滑块的left计算百分比
- var sLeft = parseInt(thisTemp.css(obj['slider'], 'left'));
- var rWidth = obj['refer'].offsetWidth - obj['slider'].offsetWidth;
- var grossValue = 0;
- if(thisTemp.isUndefined(sLeft) || isNaN(sLeft)) {
- sLeft = 0;
- }
- if(obj['grossValue'] == 'volume') {
- grossValue = 100;
- } else {
- if(thisTemp.V) {
- grossValue = thisTemp.V.duration;
- }
- }
- return parseInt(sLeft * grossValue / rWidth);
- };
- var mDown = function(event) {
- thisTemp.addListenerInside('mousemove', mMove, document);
- thisTemp.addListenerInside('mouseup', mUp, document);
- var referXY = thisTemp.getCoor(obj['refer']);
- var sliderXY = thisTemp.getCoor(obj['slider']);
- clientX = thisTemp.client(event)['x'];
- referLeft = referXY['x'];
- sliderLeft = sliderXY['x'];
- criterionWidth = clientX - sliderLeft;
- if(obj['startFun']) {
- obj['startFun'](calculation());
- }
- };
- var mMove = function(event) {
- clientX = thisTemp.client(event)['x'];
- var newX = clientX - criterionWidth - referLeft;
- if(newX < 0) {
- newX = 0;
- }
- if(newX > obj['refer'].offsetWidth - obj['slider'].offsetWidth) {
- newX = obj['refer'].offsetWidth - obj['slider'].offsetWidth;
- }
- if(obj['slider'] === thisTemp.CB['timeButton']) {
- if(!thisTemp.checkSlideLeft(newX, sliderLeft, obj['refer'].offsetWidth)) {
- return;
- }
- }
- thisTemp.css(obj['slider'], 'left', newX + 'px');
- thisTemp.css(obj['follow'], 'width', (newX + obj['slider'].offsetWidth * 0.5) + 'px');
- var nowZ = calculation();
- if(obj['monitorFun']) {
- obj['monitorFun'](nowZ);
- }
- };
- var mUp = function(event) {
- thisTemp.removeListenerInside('mousemove', mMove, document);
- thisTemp.removeListenerInside('mouseup', mUp, document);
- if(obj['endFun']) {
- obj['endFun'](calculation());
- }
- };
- var mOver = function(event) {
- if(obj['overFun']) {
- obj['overFun'](calculation());
- }
- };
- if(this.isUndefined(obj['removeListenerInside'])) {
- this.addListenerInside('mousedown', mDown, obj['slider']);
- this.addListenerInside('mouseover', mOver, obj['slider']);
- } else {
- this.removeListenerInside('mousedown', mDown, obj['slider']);
- this.removeListenerInside('mouseover', mOver, obj['slider']);
- }
- },
- /*
- 内部函数
- 判断是否可以拖动进度按钮或点击进度栏
- */
- checkSlideLeft: function(newX, sliderLeft, refer) {
- var timeSA = this.ckplayerConfig['config']['timeScheduleAdjust'];
- switch(timeSA) {
- case 0:
- return false;
- break;
- case 2:
- if(newX < sliderLeft) {
- return false;
- }
- break;
- case 3:
- if(newX > sliderLeft) {
- return false;
- }
- break;
- case 4:
- if(!this.timeSliderLeftTemp) {
- this.timeSliderLeftTemp = sliderLeft / refer;
- }
- if(newX < this.timeSliderLeftTemp * refer) {
- return false;
- }
- break;
- case 5:
- if(!this.timeSliderLeftTemp) {
- this.timeSliderLeftTemp = sliderLeft / refer;
- } else {
- var timeSliderMax = sliderLeft / refer;
- if(timeSliderMax > this.timeSliderLeftTemp) {
- this.timeSliderLeftTemp = timeSliderMax;
- }
- }
- if(newX > this.timeSliderLeftTemp * refer) {
- return false;
- }
- break;
- default:
- return true;
- break;
- }
- return true;
- },
- /*
- 内部函数
- 显示loading
- */
- loadingStart: function(rot) {
- var thisTemp = this;
- if(this.isUndefined(rot)) {
- rot = true;
- }
- if(this.showFace) {
- this.css(thisTemp.CB['loading'], 'display', 'none');
- }
- if(this.timerLoading != null) {
- if(this.timerLoading.runing) {
- this.timerLoading.stop();
- }
- this.timerLoading = null;
- }
- var buffer = 0;
- var loadingFun = function() {
- var nowRotate = '0';
- try {
- nowRotate = thisTemp.css(thisTemp.CB['loadingCanvas'], 'transform') || thisTemp.css(thisTemp.CB['loadingCanvas'], '-ms-transform') || thisTemp.css(thisTemp.CB['loadingCanvas'], '-moz-transform') || thisTemp.css(thisTemp.CB['loadingCanvas'], '-webkit-transform') || thisTemp.css(thisTemp.CB['loadingCanvas'], '-o-transform') || '0';
- } catch(event) {}
- nowRotate = parseInt(nowRotate.replace('rotate(', '').replace('deg);', ''));
- nowRotate += 4;
- if(nowRotate > 360) {
- nowRotate = 0;
- }
- if(thisTemp.showFace) {
- thisTemp.css(thisTemp.CB['loadingCanvas'], {
- transform: 'rotate(' + nowRotate + 'deg)',
- msTransform: 'rotate(' + nowRotate + 'deg)',
- mozTransform: 'rotate(' + nowRotate + 'deg)',
- webkitTransform: 'rotate(' + nowRotate + 'deg)',
- oTransform: 'rotate(' + nowRotate + 'deg)'
- });
- }
- buffer++;
- if(buffer >= 99) {
- buffer = 99;
- }
- thisTemp.sendJS('buffer', buffer);
- };
- if(rot) {
- this.timerLoading = new this.timer(10, loadingFun);
- //this.timerLoading.start();
- if(this.showFace) {
- this.css(thisTemp.CB['loading'], 'display', 'block');
- }
- } else {
- thisTemp.sendJS('buffer', 100);
- }
- },
- /*
- 内部函数
- 判断是否需要显示上一集和下一集
- */
- showFrontNext: function() {
- if(!this.showFace) {
- return;
- }
- if(this.vars['front']) {
- this.css([this.CB['front'], this.CB['frontLine']], 'display', 'block');
- } else {
- this.css([this.CB['front'], this.CB['frontLine']], 'display', 'none');
- }
- if(this.vars['next']) {
- this.css([this.CB['next'], this.CB['nextLine']], 'display', 'block');
- } else {
- this.css([this.CB['next'], this.CB['nextLine']], 'display', 'none');
- }
- },
- /*
- 内部函数
- 显示提示语
- */
- promptShow: function(ele, data) {
- if(!this.showFace) {
- return;
- }
- var obj = {};
- if(ele || data) {
- if(!this.isUndefined(data)) {
- obj = data;
- } else {
- var offsetCoor = this.getCoor(ele);
- obj = {
- title: this.getDataset(ele, 'title'),
- x: offsetCoor['x'] + ele.offsetWidth * 0.5,
- y: offsetCoor['y']
- };
- }
- this.CB['prompt'].innerHTML = obj['title'];
- this.css(this.CB['prompt'], 'display', 'block');
- var promoptWidth = this.getStringLen(obj['title']) * 10;
- this.css(this.CB['promptBg'], 'width', promoptWidth + 'px');
- this.css(this.CB['prompt'], 'width', promoptWidth + 'px');
- promoptWidth += 10;
- var x = obj['x'] - (promoptWidth * 0.5);
- var y = this.PD.offsetHeight - obj['y'] + 8;
- if(x < 0) {
- x = 0;
- }
- if(x > this.PD.offsetWidth - promoptWidth) {
- x = this.PD.offsetWidth - promoptWidth;
- }
- this.css([this.CB['promptBg'], this.CB['prompt']], {
- display: 'block',
- left: x + 'px',
- bottom: y + 'px'
- });
- } else {
- this.css([this.CB['promptBg'], this.CB['prompt']], {
- display: 'none'
- });
- }
- },
- /*
- 内部函数
- 监听错误
- */
- timerErrorFun: function() {
- var thisTemp = this;
- this.errorSend = false;
- var clearIntervalError = function(event) {
- if(thisTemp.timerError != null) {
- if(thisTemp.timerError.runing) {
- thisTemp.timerError.stop();
- }
- thisTemp.timerError = null;
- }
- };
- var errorFun = function(event) {
- clearIntervalError();
- thisTemp.error = true;
- //提取错误播放地址
- thisTemp.errorUrl = thisTemp.getVideoUrl();
- //提取错误播放地址结束
- if(!thisTemp.errorSend) {
- thisTemp.errorSend = true;
- thisTemp.sendJS('error');
- }
- if(thisTemp.showFace) {
- thisTemp.css(thisTemp.CB['errorText'], 'display', 'block');
- thisTemp.css(thisTemp.CB['pauseCenter'], 'display', 'none');
- thisTemp.css(thisTemp.CB['loading'], 'display', 'none');
- }
- thisTemp.V.removeAttribute('poster');
- thisTemp.resetPlayer();
- };
- var errorListenerFun = function(event) {
- window.setTimeout(function() {
- if(isNaN(thisTemp.V.duration)) {
- errorFun(event);
- }
- }, 500);
- };
- if(!this.errorAdd) {
- this.errorAdd = true;
- this.addListenerInside('error', errorListenerFun, this.V);
- }
- clearIntervalError();
- var timerErrorFun = function() {
- if(thisTemp.V && parseInt(thisTemp.V.networkState) == 3) {
- errorFun();
- }
- };
- this.timerError = new this.timer(this.config['errorTime'], timerErrorFun);
- //this.timerError.start();
- },
- /*
- 内部函数
- 构建判断全屏还是非全屏的判断
- */
- judgeFullScreen: function() {
- var thisTemp = this;
- if(this.timerFull != null) {
- if(this.timerFull.runing) {
- this.timerFull.stop();
- }
- this.timerFull = null;
- }
- var fullFun = function() {
- thisTemp.isFullScreen();
- };
- this.timerFull = new this.timer(20, fullFun);
- },
- /*
- 内部函数
- 判断是否是全屏
- */
- isFullScreen: function() {
- if(!this.showFace) {
- return;
- }
- var fullState = document.fullScreen || document.mozFullScreen || document.webkitIsFullScreen || document.msFullscreenElement;
- if(fullState && !this.full) {
- this.full = true;
- this.sendJS('full', true);
- this.elementCoordinate();
- this.css(this.CB['full'], 'display', 'none');
- this.css(this.CB['escFull'], 'display', 'block');
- if(this.vars['live'] == 0) {
- this.timeUpdateHandler();
- }
- this.PD.appendChild(this.CB['menu']);
- }
- if(!fullState && this.full) {
- this.full = false;
- this.sendJS('full', false);
- this.elementCoordinate();
- this.css(this.CB['full'], 'display', 'block');
- this.css(this.CB['escFull'], 'display', 'none');
- if(this.timerFull != null) {
- if(this.timerFull.runing) {
- this.timerFull.stop();
- }
- this.timerFull = null;
- }
- if(this.vars['live'] == 0) {
- this.timeUpdateHandler();
- }
- this.body.appendChild(this.CB['menu']);
- }
- },
- /*
- 内部函数
- 构建右键内容及注册相关动作事件
- */
- newMenu: function() {
- var thisTemp = this;
- var i = 0;
- this.css(this.CB['menu'], {
- backgroundColor: '#FFFFFF',
- padding: '5px',
- position: 'absolute',
- left: '10px',
- top: '20px',
- display: 'none',
- zIndex: '999',
- color: '#A1A9BE',
- boxShadow: '2px 2px 3px #AAAAAA'
- });
- var mArr = this.contextMenu;
- var cMenu = this.ckplayerConfig['menu'];
- if(cMenu['name']) {
- if(cMenu['link']) {
- mArr[0] = [cMenu['name'], 'link', cMenu['link']];
- } else {
- mArr[0] = [cMenu['name'], 'default'];
- }
- }
- if(cMenu['version']) {
- mArr[1] = [cMenu['version'], 'default', 'line'];
- }
- if(cMenu['more']) {
- if(typeof(cMenu['more']) == 'object') {
- if(cMenu['more'].length > 0) {
- var moreArr = cMenu['more'];
- for(i = 0; i < moreArr.length; i++) {
- var mTemp = moreArr[i];
- var arrTemp = [];
- if(mTemp['name']) {
- arrTemp.push(mTemp['name']);
- }
- if(mTemp['clickEvent'] && mTemp['clickEvent'] != 'none') {
- var eveObj = this.clickEvent(mTemp['clickEvent']);
- arrTemp.push(eveObj['type']);
- if(eveObj['fun']) {
- arrTemp.push(eveObj['fun']);
- }
- if(eveObj['link']) {
- arrTemp.push(eveObj['link']);
- }
- if(eveObj['target']) {
- arrTemp.push(' target="' + eveObj['target'] + '"');
- }
- }
- if(mTemp['separatorBefore']) {
- arrTemp.push('line');
- }
- mArr.push(arrTemp);
- }
- }
- }
- }
- var html = '';
- for(i = 0; i < mArr.length; i++) {
- var me = mArr[i];
- switch(me[1]) {
- case 'default':
- html += '<p>' + me[0] + '</p>';
- break;
- case 'link':
- html += '<p><a href="' + me[2] + '"' + me[3] + '>' + me[0] + '</a></p>';
- break;
- case 'javaScript':
- html += '<p><a href="javascript:' + me[2] + '">' + me[0] + '</a></p>';
- break;
- case 'actionScript':
- html += '<p><a href="javascript:' + this.vars['variable'] + me[2].replace('thisTemp', '') + '">' + me[0] + '</a></p>';
- break;
- default:
- break;
- }
- }
- this.CB['menu'].innerHTML = html;
- var pArr = this.CB['menu'].childNodes;
- for(i = 0; i < pArr.length; i++) {
- this.css(pArr[i], {
- height: '30px',
- lineHeight: '30px',
- margin: '0px',
- fontFamily: this.fontFamily,
- fontSize: '12px',
- paddingLeft: '10px',
- paddingRight: '30px'
- });
- if(mArr[i][mArr[i].length - 1] == 'line') {
- this.css(pArr[i], 'borderBottom', '1px solid #e9e9e9');
- }
- var aArr = pArr[i].childNodes;
- for(var n = 0; n < aArr.length; n++) {
- if(aArr[n].localName == 'a') {
- this.css(aArr[n], {
- color: '#000000',
- textDecoration: 'none'
- });
- }
- }
- }
- this.PD.oncontextmenu = function(event) {
- var eve = event || window.event;
- var client = thisTemp.client(event);
- if(eve.button == 2) {
- eve.returnvalue = false;
- var x = client['x'] + thisTemp.pdCoor['x'] - 2;
- var y = client['y'] + thisTemp.pdCoor['y'] - 2;
- thisTemp.css(thisTemp.CB['menu'], {
- display: 'block',
- left: x + 'px',
- top: y + 'px'
- });
- return false;
- }
- return true;
- };
- var setTimeOutPClose = function() {
- if(setTimeOutP) {
- window.clearTimeout(setTimeOutP);
- setTimeOutP = null;
- }
- };
- var setTimeOutP = null;
- var mouseOut = function(event) {
- setTimeOutPClose();
- setTimeOutP = window.setTimeout(function(event) {
- thisTemp.css(thisTemp.CB['menu'], 'display', 'none');
- }, 500);
- };
- this.addListenerInside('mouseout', mouseOut, thisTemp.CB['menu']);
- var mouseOver = function(event) {
- setTimeOutPClose();
- };
- this.addListenerInside('mouseover', mouseOver, thisTemp.CB['menu']);
- },
- /*
- 内部函数
- 构建控制栏隐藏事件
- */
- controlBarHide: function(hide) {
- var thisTemp = this;
- var client = {
- x: 0,
- y: 0
- },
- oldClient = {
- x: 0,
- y: 0
- };
- var cShow = true,
- force = false;
- var oldCoor = [0, 0];
- var controlBarShow = function(show) {
- if(show && !cShow && thisTemp.controlBarIsShow) {
- cShow = true;
- thisTemp.sendJS('controlBar', true);
- thisTemp.css(thisTemp.CB['controlBarBg'], 'display', 'block');
- thisTemp.css(thisTemp.CB['controlBar'], 'display', 'block');
- thisTemp.css(thisTemp.CB['timeProgressBg'], 'display', 'block');
- thisTemp.css(thisTemp.CB['timeBoBg'], 'display', 'block');
- thisTemp.changeVolume(thisTemp.volume);
- thisTemp.changeLoad();
- if(!thisTemp.timerBuffer) {
- thisTemp.bufferEdHandler();
- }
- } else {
- if(cShow) {
- cShow = false;
- var paused = thisTemp.getMetaDate()['paused'];
- if(force) {
- paused = false;
- }
- if(!paused) {
- thisTemp.sendJS('controlBar', false);
- thisTemp.css(thisTemp.CB['controlBarBg'], 'display', 'none');
- thisTemp.css(thisTemp.CB['controlBar'], 'display', 'none');
- thisTemp.css(thisTemp.CB['timeProgressBg'], 'display', 'none');
- thisTemp.css(thisTemp.CB['timeBoBg'], 'display', 'none');
- thisTemp.promptShow(false);
- }
- }
- }
- };
- var cbarFun = function(event) {
- if(client['x'] == oldClient['x'] && client['y'] == oldClient['y']) {
- var cdH = parseInt(thisTemp.CD.offsetHeight);
- if((client['y'] < cdH - 50 || client['y'] > cdH - 2) && cShow) {
- controlBarShow(false);
- }
- } else {
- if(!cShow) {
- controlBarShow(true);
- }
- }
- oldClient = {
- x: client['x'],
- y: client['y']
- }
- };
- this.timerCBar = new this.timer(2000, cbarFun);
- var cdMove = function(event) {
- var getClient = thisTemp.client(event);
- client['x'] = getClient['x'];
- client['y'] = getClient['y'];
- if(!cShow) {
- controlBarShow(true);
- }
- };
- this.addListenerInside('mousemove', cdMove, thisTemp.CD);
- this.addListenerInside('ended', cdMove);
- this.addListenerInside('resize', cdMove, window);
- if(hide === true) {
- cShow = true;
- force = true;
- controlBarShow(false);
- }
- if(hide === false) {
- cShow = false;
- force = true;
- controlBarShow(true);
- }
- },
- /*
- 内部函数
- 注册键盘按键事件
- */
- keypress: function() {
- var thisTemp = this;
- var keyDown = function(eve) {
- var keycode = eve.keyCode || eve.which;
- switch(keycode) {
- case 32:
- thisTemp.playOrPause();
- break;
- case 37:
- thisTemp.fastBack();
- break;
- case 39:
- thisTemp.fastNext();
- break;
- case 38:
- now = thisTemp.volume + thisTemp.ckplayerConfig['config']['volumeJump'];
- thisTemp.changeVolume(now > 1 ? 1 : now);
- break;
- case 40:
- now = thisTemp.volume - thisTemp.ckplayerConfig['config']['volumeJump'];
- thisTemp.changeVolume(now < 0 ? 0 : now);
- break;
- default:
- break;
- }
- };
- this.addListenerInside('keydown', keyDown, window || document);
- },
- /*
- 内部函数
- 注册倍速相关
- */
- playbackRate: function() {
- if(!this.showFace) {
- return;
- }
- var thisTemp = this;
- var vArr = this.playbackRateArr;
- var html = '';
- var nowD = ''; //当前的清晰度
- var i = 0;
- if(!nowD) {
- nowD = vArr[this.playbackRateDefault][1];
- }
- if(vArr.length > 1) {
- var zlen = 0;
- for(i = 0; i < vArr.length; i++) {
- html = '<p>' + vArr[i][1] + '</p>' + html;
- var dlen = this.getStringLen(vArr[i][1]);
- if(dlen > zlen) {
- zlen = dlen;
- }
- }
- if(html) {
- html += '<p>' + nowD + '</p>';
- }
- this.CB['playbackrate'].innerHTML = nowD;
- this.CB['playbackrateP'].innerHTML = html;
- this.css([this.CB['playbackrate'], this.CB['playbackrateLine']], 'display', 'block');
- var pArr = this.CB['playbackrateP'].childNodes;
- for(var i = 0; i < pArr.length; i++) {
- var fontColor = '#FFFFFF';
- if(pArr[i].innerHTML == nowD) {
- fontColor = '#0782F5';
- }
- this.css(pArr[i], {
- color: fontColor,
- margin: '0px',
- padding: '0px',
- fontSize: '14px'
- });
- if(i < pArr.length - 1) {
- this.css(pArr[i], 'borderBottom', '1px solid #282828')
- }
- var defClick = function(event) {
- if(nowD != this.innerHTML) {
- thisTemp.css(thisTemp.CB['playbackrateP'], 'display', 'none');
- thisTemp.newPlaybackrate(this.innerHTML);
- thisTemp.sendJS('clickEvent', 'actionScript->newPlaybackrate');
- }
- };
- this.addListenerInside('click', defClick, pArr[i]);
- }
- var pW = (zlen * 10) + 20;
- this.css(this.CB['playbackrateP'], {
- width: pW + 'px'
- });
- this.css(this.CB['playbackrate'], {
- width: pW + 'px'
- });
- this.buttonWidth['playbackrate'] = this.CB['playbackrate'].offsetWidth;
- } else {
- this.CB['playbackrate'].innerHTML = '';
- this.CB['playbackrateP'].innerHTML = '';
- this.css([this.CB['playbackrate'], this.CB['playbackrateLine']], 'display', 'none');
- }
- },
- /*
- 内部函数
- 注册切换倍速播放相关事件
- */
- addPlaybackrate: function() {
- var thisTemp = this;
- var setTimeOutP = null;
- var defClick = function(event) {
- thisTemp.css(thisTemp.CB['playbackrateP'], {
- left: thisTemp.getCoor(thisTemp.CB['playbackrate'])['x'] + 'px',
- display: 'block'
- });
- };
- this.addListenerInside('click', defClick, this.CB['playbackrate']);
- var defMouseOut = function(event) {
- if(setTimeOutP) {
- window.clearTimeout(setTimeOutP);
- setTimeOutP = null;
- }
- setTimeOutP = window.setTimeout(function(event) {
- thisTemp.css(thisTemp.CB['playbackrateP'], 'display', 'none');
- }, 500);
- };
- this.addListenerInside('mouseout', defMouseOut, thisTemp.CB['playbackrateP']);
- var defMouseOver = function(event) {
- if(setTimeOutP) {
- window.clearTimeout(setTimeOutP);
- setTimeOutP = null;
- }
- };
- this.addListenerInside('mouseover', defMouseOver, thisTemp.CB['playbackrateP']);
- },
- /*
- 内部函数
- 切换倍速后发生的动作
- */
- newPlaybackrate: function(title) {
- var vArr = this.playbackRateArr;
- var nVArr = [];
- var i = 0;
- for(i = 0; i < vArr.length; i++) {
- var v = vArr[i];
- if(v[1] == title) {
- this.playbackRateDefault = i;
- this.V.playbackRate = v[0];
- if(this.showFace) {
- this.CB['playbackrate'].innerHTML = v[1];
- this.playbackRate();
- }
- this.sendJS('playbackRate', v);
- }
- }
- },
- /*
- 内部函数
- 构建清晰度按钮及切换事件(Click事件)
- */
- definition: function() {
- if(!this.showFace) {
- return;
- }
- var thisTemp = this;
- var vArr = this.VA;
- var dArr = [];
- var html = '';
- var nowD = ''; //当前的清晰度
- var i = 0;
- for(i = 0; i < vArr.length; i++) {
- var d = vArr[i][2];
- if(dArr.indexOf(d) == -1) {
- dArr.push(d);
- }
- if(this.V) {
- if(vArr[i][0] == this.V.currentSrc) {
- nowD = d;
- }
- }
- }
- if(!nowD) {
- nowD = dArr[0];
- }
- if(dArr.length > 1) {
- var zlen = 0;
- for(i = dArr.length - 1; i > -1; i--) {
- html = '<p>' + dArr[i] + '</p>' + html;
- var dlen = this.getStringLen(dArr[i]);
- if(dlen > zlen) {
- zlen = dlen;
- }
- }
- if(html) {
- html += '<p>' + nowD + '</p>';
- }
- this.CB['definition'].innerHTML = nowD;
- this.CB['definitionP'].innerHTML = html;
- this.css([this.CB['definition'], this.CB['definitionLine']], 'display', 'block');
- var pArr = this.CB['definitionP'].childNodes;
- for(var i = 0; i < pArr.length; i++) {
- var fontColor = '#FFFFFF';
- if(pArr[i].innerHTML == nowD) {
- fontColor = '#0782F5';
- }
- this.css(pArr[i], {
- color: fontColor,
- margin: '0px',
- padding: '0px',
- fontSize: '14px'
- });
- if(i < pArr.length - 1) {
- this.css(pArr[i], 'borderBottom', '1px solid #282828')
- }
- var defClick = function() {
- if(nowD != this.innerHTML) {
- thisTemp.css(thisTemp.CB['definitionP'], 'display', 'none');
- thisTemp.newDefinition(this.innerHTML);
- }
- };
- this.addListenerInside('click', defClick, pArr[i]);
- }
- var pW = (zlen * 10) + 20;
- this.css(this.CB['definitionP'], {
- width: pW + 'px'
- });
- this.css(this.CB['definition'], {
- width: pW + 'px'
- });
- this.buttonWidth['definition'] = this.CB['definition'].offsetWidth;
- } else {
- this.CB['definition'].innerHTML = '';
- this.CB['definitionP'].innerHTML = '';
- this.css([this.CB['definition'], this.CB['definitionLine']], 'display', 'none');
- }
- },
- /*
- 内部函数
- 注册清晰度相关事件
- */
- addDefListener: function() {
- var thisTemp = this;
- var setTimeOutP = null;
- var defClick = function(event) {
- thisTemp.css(thisTemp.CB['definitionP'], {
- left: thisTemp.getCoor(thisTemp.CB['definition'])['x'] + 'px',
- display: 'block'
- });
- };
- this.addListenerInside('click', defClick, this.CB['definition']);
- var defMouseOut = function(event) {
- if(setTimeOutP) {
- window.clearTimeout(setTimeOutP);
- setTimeOutP = null;
- }
- setTimeOutP = window.setTimeout(function(event) {
- thisTemp.css(thisTemp.CB['definitionP'], 'display', 'none');
- }, 500);
- };
- this.addListenerInside('mouseout', defMouseOut, thisTemp.CB['definitionP']);
- var defMouseOver = function(event) {
- if(setTimeOutP) {
- window.clearTimeout(setTimeOutP);
- setTimeOutP = null;
- }
- };
- this.addListenerInside('mouseover', defMouseOver, thisTemp.CB['definitionP']);
- },
- /*
- 内部函数
- 切换清晰度后发生的动作
- */
- newDefinition: function(title) {
- var vArr = this.VA;
- var nVArr = [];
- var i = 0;
- for(i = 0; i < vArr.length; i++) {
- var v = vArr[i];
- if(v[2] == title) {
- nVArr.push(v);
- this.sendJS('definitionChange', i + '');
- }
- }
- if(nVArr.length < 1) {
- return;
- }
- if(this.V != null && this.needSeek == 0) {
- this.needSeek = this.V.currentTime;
- }
- if(this.getFileExt(nVArr[0][0]) != '.m3u8') {
- this.isM3u8 = false;
- }
- if(!this.isM3u8) {
- if(nVArr.length == 1) {
- this.V.innerHTML = '';
- this.V.src = nVArr[0][0];
- } else {
- var source = '';
- nVArr = this.arrSort(nVArr);
- for(i = 0; i < nVArr.length; i++) {
- var type = '';
- var va = nVArr[i];
- if(va[1]) {
- type = ' type="' + va[1] + '"';
- }
- source += '<source src="' + va[0] + '"' + type + '>';
- }
- this.V.removeAttribute('src');
- this.V.innerHTML = source;
- }
- } else {
- this.embedHls(vArr[0][0], this.vars['autoplay']);
- }
- this.V.autoplay = 'autoplay';
- this.V.load();
- this.timerErrorFun();
- },
- /*
- 内置函数
- 播放hls
- */
- embedHls: function(url, autoplay) {
- var thisTemp = this;
- if(Hls.isSupported()) {
- var hls = new Hls();
- hls.loadSource(url);
- hls.attachMedia(this.V);
- hls.on(Hls.Events.MANIFEST_PARSED, function() {
- thisTemp.playerLoad();
- if(autoplay) {
- thisTemp.videoPlay();
- }
- });
- }
- },
- /*
- 内部函数
- 构建提示点
- */
- prompt: function() {
- if(!this.showFace) {
- return;
- }
- var thisTemp = this;
- var prompt = this.vars['promptSpot'];
- if(prompt == null || this.promptArr.length > 0) {
- return;
- }
- var showPrompt = function(event) {
- if(thisTemp.promptElement == null) {
- var random2 = 'prompte' + thisTemp.randomString(5);
- var ele2 = document.createElement('div');
- ele2.className = random2;
- thisTemp.PD.appendChild(ele2);
- thisTemp.promptElement = thisTemp.getByElement(random2);
- thisTemp.css(thisTemp.promptElement, {
- overflowX: 'hidden',
- lineHeight: '22px',
- fontSize: '14px',
- color: '#FFFFFF',
- position: 'absolute',
- display: 'block',
- zIndex: '90'
- });
- }
- var pcon = thisTemp.getPromptTest();
- var pW = pcon['pW'],
- pT = pcon['pT'],
- pL = parseInt(thisTemp.css(this, 'left')) - parseInt(pW * 0.5);
- if(pcon['pL'] > 10) {
- pL = pcon['pL'];
- }
- if(pL < 0) {
- pL = 0;
- }
- thisTemp.css(thisTemp.promptElement, {
- width: pW + 'px',
- left: (-pW - 10) + 'px',
- display: 'block'
- });
- thisTemp.promptElement.innerHTML = thisTemp.getDataset(this, 'words');
- thisTemp.css(thisTemp.promptElement, {
- left: pL + 'px',
- top: (pT - thisTemp.promptElement.offsetHeight - 10) + 'px'
- });
- };
- var hidePrompt = function(event) {
- if(thisTemp.promptElement != null) {
- thisTemp.css(thisTemp.promptElement, {
- display: 'none'
- });
- }
- };
- var i = 0;
- for(i = 0; i < prompt.length; i++) {
- var pr = prompt[i];
- var words = pr['words'];
- var time = pr['time'];
- var random = 'prompt' + this.randomString(5);
- var ele = document.createElement('div');
- ele.className = random;
- this.CB['timeBoBg'].appendChild(ele);
- var div = this.getByElement(random);
- div.setAttribute('data-time', time);
- div.setAttribute('data-words', words);
- this.css(div, {
- width: '6px',
- height: '6px',
- backgroundColor: '#FFFFFF',
- position: 'absolute',
- top: '4px',
- left: '-100px',
- display: 'none',
- zIndex: '1',
- borderRadius: '6px'
- });
- this.addListenerInside('mouseover', showPrompt, div);
- this.addListenerInside('mouseout', hidePrompt, div);
- this.promptArr.push(div);
- }
- this.changePrompt();
- },
- /*
- 内部函数
- 计算提示文本的位置
- */
- getPromptTest: function() {
- var pW = this.previewWidth,
- pT = this.getCoor(this.CB['timeButton'])['y'],
- pL = 0;
- if(this.previewTop != null) {
- pT -= parseInt(this.css(this.previewTop, 'height'));
- pL = parseInt(this.css(this.previewTop, 'left'));
- } else {
- pT -= 35;
- }
- pL += 2;
- if(pL < 0) {
- pL = 0;
- }
- if(pL > this.PD.offsetWidth - pW) {
- pL = this.PD.offsetWidth - pW;
- }
- return {
- pW: pW,
- pT: pT,
- pL: pL
- };
- },
- /*
- 内部函数
- 删除提示点
- */
- deletePrompt: function() {
- var arr = this.promptArr;
- if(arr.length > 0) {
- for(var i = 0; i < arr.length; i++) {
- if(arr[i]) {
- this.deleteChild(arr[i]);
- }
- }
- }
- this.promptArr = [];
- },
- /*
- 内部函数
- 计算提示点坐标
- */
- changePrompt: function() {
- if(this.promptArr.length == 0) {
- return;
- }
- var arr = this.promptArr;
- var duration = this.getMetaDate()['duration'];
- var bw = this.CB['timeBoBg'].offsetWidth;
- for(var i = 0; i < arr.length; i++) {
- var time = parseInt(this.getDataset(arr[i], 'time'));
- var left = parseInt(time * bw / duration) - parseInt(arr[i].offsetWidth * 0.5);
- if(left < 0) {
- left = 0;
- }
- if(left > bw - parseInt(arr[i].offsetWidth * 0.5)) {
- left = bw - parseInt(arr[i].offsetWidth * 0.5);
- }
- this.css(arr[i], {
- left: left + 'px',
- display: 'block'
- });
- }
- },
- /*
- 内部函数
- 构建预览图片效果
- */
- preview: function(obj) {
- var thisTemp = this;
- var preview = {
- file: null,
- scale: 0
- };
- preview = this.standardization(preview, this.vars['preview']);
- if(preview['file'] == null || preview['scale'] <= 0) {
- return;
- }
- var srcArr = preview['file'];
- if(this.previewStart == 0) { //如果还没有构建,则先进行构建
- this.previewStart = 1;
- if(srcArr.length > 0) {
- var i = 0;
- var imgW = 0,
- imgH = 0;
- var random = thisTemp.randomString(10);
- var loadNum = 0;
- var loadImg = function(i) {
- srcArr[i] = thisTemp.getNewUrl(srcArr[i]);
- var n = 0;
- var img = new Image();
- img.src = srcArr[i];
- img.className = random + i;
- img.onload = function(event) {
- loadNum++;
- if(thisTemp.previewDiv == null) { //如果没有建立DIV,则建
- imgW = img.width;
- imgH = img.height;
- thisTemp.previewWidth = parseInt(imgW * 0.1);
- var ele = document.createElement('div');
- ele.className = random;
- thisTemp.PD.appendChild(ele);
- thisTemp.previewDiv = thisTemp.getByElement(random);
- var eleTop = (obj['y'] - parseInt(imgH * 0.1) + 2);
- thisTemp.css(thisTemp.previewDiv, {
- width: srcArr.length * imgW * 10 + 'px',
- height: parseInt(imgH * 0.1) + 'px',
- backgroundColor: '#000000',
- position: 'absolute',
- left: '0px',
- top: eleTop + 'px',
- display: 'none',
- zIndex: '80'
- });
- ele.setAttribute('data-x', '0');
- ele.setAttribute('data-y', eleTop);
- var ele2 = document.createElement('div');
- ele2.className = random + 'd2';
- thisTemp.PD.appendChild(ele2);
- thisTemp.previewTop = thisTemp.getByElement(ele2.className);
- thisTemp.css(thisTemp.previewTop, {
- width: parseInt(imgW * 0.1) + 'px',
- height: parseInt(imgH * 0.1) + 'px',
- position: 'absolute',
- border: '5px solid ' + thisTemp.css(thisTemp.CB['timeProgress'], 'backgroundColor'),
- left: '0px',
- top: (obj['y'] - parseInt(imgH * 0.1) + 2) + 'px',
- display: 'none',
- zIndex: '81'
- });
- var html = '';
- for(n = 0; n < srcArr.length; n++) {
- html += thisTemp.newCanvas(random + n, imgW * 10, parseInt(imgH * 0.1))
- }
- thisTemp.previewDiv.innerHTML = html;
- }
- thisTemp.previewDiv.appendChild(img);
- var cimg = thisTemp.getByElement(img.className);
- var canvas = thisTemp.getByElement(img.className + '-canvas');
- var context = canvas.getContext('2d');
- var sx = 0,
- sy = 0,
- x = 0,
- h = parseInt(imgH * 0.1);
- for(n = 0; n < 100; n++) {
- x = parseInt(n * imgW * 0.1);
- context.drawImage(cimg, sx, sy, parseInt(imgW * 0.1), h, x, 0, parseInt(imgW * 0.1), h);
- sx += parseInt(imgW * 0.1);
- if(sx >= imgW) {
- sx = 0;
- sy += h;
- }
- thisTemp.css(cimg, 'display', 'none');
- }
- if(loadNum == srcArr.length) {
- thisTemp.previewStart = 2;
- } else {
- i++;
- loadImg(i);
- }
- };
- };
- }
- loadImg(i);
- return;
- }
- if(this.previewStart == 2) {
- var isTween = true;
- var nowNum = parseInt(obj['time'] / this.vars['preview']['scale']);
- var numTotal = parseInt(thisTemp.getMetaDate()['duration'] / this.vars['preview']['scale']);
- if(thisTemp.css(thisTemp.previewDiv, 'display') == 'none') {
- isTween = false;
- }
- thisTemp.css(thisTemp.previewDiv, 'display', 'block');
- var imgWidth = thisTemp.previewDiv.offsetWidth * 0.01 / srcArr.length;
- var left = (imgWidth * nowNum) - obj['x'] + parseInt(imgWidth * 0.5),
- top = obj['y'] - thisTemp.previewDiv.offsetHeight;
- thisTemp.css(thisTemp.previewDiv, 'top', top + 2 + 'px');
- var topLeft = obj['x'] - parseInt(imgWidth * 0.5);
- var timepieces = 0;
- if(topLeft < 0) {
- topLeft = 0;
- timepieces = obj['x'] - topLeft - imgWidth * 0.5;
- }
- if(topLeft > thisTemp.PD.offsetWidth - imgWidth) {
- topLeft = thisTemp.PD.offsetWidth - imgWidth;
- timepieces = obj['x'] - topLeft - imgWidth * 0.5;
- }
- if(left < 0) {
- left = 0;
- }
- if(left > numTotal * imgWidth - thisTemp.PD.offsetWidth) {
- left = numTotal * imgWidth - thisTemp.PD.offsetWidth;
- }
- thisTemp.css(thisTemp.previewTop, {
- left: topLeft + 'px',
- top: top + 2 + 'px',
- display: 'block'
- });
- if(thisTemp.previewTop.offsetHeight > thisTemp.previewDiv.offsetHeight) {
- thisTemp.css(thisTemp.previewTop, {
- height: thisTemp.previewDiv.offsetHeight - (thisTemp.previewTop.offsetHeight - thisTemp.previewDiv.offsetHeight) + 'px'
- });
- }
- if(this.previewTween != null) {
- this.animatePause(this.previewTween);
- this.previewTween = null
- }
- var nowLeft = parseInt(thisTemp.css(thisTemp.previewDiv, 'left'));
- var leftC = nowLeft + left;
- if(nowLeft == -(left + timepieces)) {
- return;
- }
- if(isTween) {
- var obj = {
- element: thisTemp.previewDiv,
- start: null,
- end: -(left + timepieces),
- speed: 0.3
- };
- this.previewTween = this.animate(obj);
- } else {
- thisTemp.css(thisTemp.previewDiv, 'left', -(left + timepieces) + 'px')
- }
- }
- },
- /*
- 内部函数
- 删除预览图节点
- */
- deletePreview: function() {
- if(this.previewDiv != null) {
- this.deleteChild(this.previewDiv);
- this.previewDiv = null;
- this.previewStart = 0;
- }
- },
- /*
- 内部函数
- 修改视频地址,属性
- */
- changeVideo: function() {
- if(!this.html5Video) {
- this.getVarsObject();
- this.V.newVideo(this.vars);
- return;
- }
- var vArr = this.VA;
- var v = this.vars;
- var i = 0;
- if(vArr.length < 1) {
- return;
- }
- if(this.V != null && this.needSeek == 0) {
- this.needSeek = this.V.currentTime;
- }
- if(v['poster']) {
- this.V.poster = v['poster'];
- } else {
- this.V.removeAttribute('poster');
- }
- if(v['loop']) {
- this.V.loop = 'loop';
- } else {
- this.V.removeAttribute('loop');
- }
- if(v['seek'] > 0) {
- this.needSeek = v['seek'];
- } else {
- this.needSeek = 0;
- }
- if(this.getFileExt(vArr[0][0]) != '.m3u8') {
- this.isM3u8 = false;
- }
- if(!this.isM3u8) {
- if(vArr.length == 1) {
- this.V.innerHTML = '';
- this.V.src = vArr[0][0];
- } else {
- var source = '';
- vArr = this.arrSort(vArr);
- for(i = 0; i < vArr.length; i++) {
- var type = '';
- var va = vArr[i];
- if(va[1]) {
- type = ' type="' + va[1] + '"';
- }
- source += '<source src="' + va[0] + '"' + type + '>';
- }
- this.V.removeAttribute('src');
- this.V.innerHTML = source;
- }
- //分析视频地址结束
- if(v['autoplay']) {
- this.V.autoplay = 'autoplay';
- } else {
- this.V.removeAttribute('autoplay');
- }
- this.V.load();
- } else {
- this.embedHls(vArr[0][0], v['autoplay']);
- }
- if(!this.isUndefined(v['volume'])) {
- this.changeVolume(v['volume']);
- }
- this.resetPlayer(); //重置界面元素
- this.timerErrorFun();
- //如果存在字幕则加载
- if(this.vars['cktrack']) {
- this.loadTrack();
- }
- },
- /*
- 内部函数
- 调整中间暂停按钮,缓冲loading,错误提示文本框的位置
- */
- elementCoordinate: function() {
- this.pdCoor = this.getXY(this.PD);
- this.css(this.CB['pauseCenter'], {
- left: parseInt((this.PD.offsetWidth - 80) * 0.5) + 'px',
- top: parseInt((this.PD.offsetHeight - 80) * 0.5) + 'px'
- });
- this.css(this.CB['loading'], {
- left: parseInt((this.PD.offsetWidth - 60) * 0.5) + 'px',
- top: parseInt((this.PD.offsetHeight - 60) * 0.5) + 'px'
- });
- this.css(this.CB['errorText'], {
- left: parseInt((this.PD.offsetWidth - 120) * 0.5) + 'px',
- top: parseInt((this.PD.offsetHeight - 30) * 0.5) + 'px'
- });
- this.css(this.CB['logo'], {
- left: parseInt(this.PD.offsetWidth - this.CB['logo'].offsetWidth - 20) + 'px',
- top: '20px'
- });
- this.checkBarWidth();
- },
- /*
- 内部函数
- 当播放器尺寸变化时,显示和隐藏相关节点
- */
- checkBarWidth: function() {
- if(!this.showFace) {
- return;
- }
- var controlBarW = this.CB['controlBar'].offsetWidth;
- var ele = [];
- ele.push([
- [this.CB['full'], this.CB['escFull'], this.CB['fullLine']], this.buttonWidth['full'] + 2, 'full'
- ]);
- if(this.vars['front'] != '') {
- ele.push([
- [this.CB['front'], this.CB['frontLine']], this.buttonWidth['front'] + 2
- ]);
- }
- if(this.vars['next'] != '') {
- ele.push([
- [this.CB['next'], this.CB['nextLine']], this.buttonWidth['next'] + 2
- ]);
- }
- if(this.CB['definition'].innerHTML != '') {
- ele.push([
- [this.CB['definition'], this.CB['definitionLine']], this.buttonWidth['definition'] + 2
- ]);
- }
- ele.push([
- [this.CB['volume']], this.buttonWidth['volume']
- ]);
- ele.push([
- [this.CB['mute'], this.CB['escMute'], this.CB['muteLine']], this.buttonWidth['mute'] + 2, 'mute'
- ]);
- ele.push([
- [this.CB['timeText']], this.buttonWidth['timeText']
- ]);
- ele.push([
- [this.CB['play'], this.CB['pause'], this.CB['playLine']], this.buttonWidth['play'] + 2, 'play'
- ]);
- var i = 0;
- var len = 0;
- var isc = true;
- //计算所有要显示的节点的总宽度
- for(var i = 0; i < ele.length; i++) {
- var nlen = ele[i][1];
- if(nlen > 2) {
- len += nlen;
- } else {
- isc = false;
- }
- }
- if(isc) {
- this.buttonLen = len;
- this.buttonArr = ele;
- }
- len = this.buttonLen;
- ele = this.buttonArr;
- for(var i = 0; i < ele.length; i++) {
- if(len > controlBarW) {
- len -= ele[i][1];
- this.css(ele[i][0], 'display', 'none');
- } else {
- this.css(ele[i][0], 'display', 'block');
- if(ele[i].length == 3) {
- var name = ele[i][2];
- switch(name) {
- case 'mute':
- if(this.volume == 0) {
- this.css(this.CB['mute'], 'display', 'none');
- } else {
- this.css(this.CB['escMute'], 'display', 'none');
- }
- break;
- case 'play':
- this.playShow(this.V.paused ? false : true);
- break;
- case 'full':
- if(this.full) {
- this.css(this.CB['full'], 'display', 'none');
- } else {
- this.css(this.CB['escFull'], 'display', 'none');
- }
- break;
- }
- }
- }
- }
- },
- /*
- 内部函数
- 初始化暂停或播放按钮
- */
- initPlayPause: function() {
- if(!this.showFace) {
- return;
- }
- if(this.vars['autoplay']) {
- this.css([this.CB['play'], this.CB['pauseCenter']], 'display', 'none');
- this.css(this.CB['pause'], 'display', 'block');
- } else {
- this.css(this.CB['play'], 'display', 'block');
- if(this.css(this.CB['errorText'], 'display') == 'none') {
- this.css(this.CB['pauseCenter'], 'display', 'block');
- }
- this.css(this.CB['pause'], 'display', 'none');
- }
- },
- /*
- 下面为监听事件
- 内部函数
- 监听元数据已加载
- */
- loadedHandler: function() {
- this.loaded = true;
- if(this.vars['loaded'] != '') {
- try {
- eval(this.vars['loaded'] + '()');
- } catch(event) {
- this.log(event);
- }
- }
- },
- /*
- 内部函数
- 监听播放
- */
- playingHandler: function() {
- this.playShow(true);
- if(this.needSeek > 0) {
- this.videoSeek(this.needSeek);
- this.needSeek = 0;
- }
- if(this.animatePauseArray.length > 0) {
- this.animateResume('pause');
- }
- if(this.playerType == 'html5video' && this.V != null && this.config['videoDrawImage']) {
- this.sendVCanvas();
- }
- },
- /*
- 内部函数
- 使用画布附加视频
- */
- sendVCanvas: function() {
- if(this.timerVCanvas == null) {
- this.css(this.V, 'display', 'none');
- this.css(this.MD, 'display', 'block');
- var thisTemp = this;
- var videoCanvas = function() {
- if(thisTemp.MDCX.width != thisTemp.PD.offsetWidth) {
- thisTemp.MDC.width = thisTemp.PD.offsetWidth;
- }
- if(thisTemp.MDCX.height != thisTemp.PD.offsetHeight) {
- thisTemp.MDC.height = thisTemp.PD.offsetHeight;
- }
- thisTemp.MDCX.clearRect(0, 0, thisTemp.MDCX.width, thisTemp.MDCX.height);
- var coor = thisTemp.getProportionCoor(thisTemp.PD.offsetWidth, thisTemp.PD.offsetHeight, thisTemp.V.videoWidth, thisTemp.V.videoHeight);
- thisTemp.MDCX.drawImage(thisTemp.V, 0, 0, thisTemp.V.videoWidth, thisTemp.V.videoHeight, coor['x'], coor['y'], coor['width'], coor['height']);
- };
- this.timerVCanvas = new this.timer(0, videoCanvas);
- }
- },
- /*
- 内部函数
- 监听暂停
- */
- pauseHandler: function() {
- this.playShow(false);
- if(this.animatePauseArray.length > 0) {
- this.animatePause('pause');
- }
- if(this.playerType == 'html5video' && this.V != null && this.config['videoDrawImage']) {
- this.stopVCanvas();
- }
- },
- /*
- 内部函数
- 停止画布
- */
- stopVCanvas: function() {
- if(this.timerVCanvas != null) {
- this.css(this.V, 'display', 'block');
- this.css(this.MD, 'display', 'none');
- if(this.timerVCanvas.runing) {
- this.timerVCanvas.stop();
- }
- this.timerVCanvas = null;
- }
- },
- /*
- 内部函数
- 根据当前播放还是暂停确认图标显示
- */
- playShow: function(b) {
- if(!this.showFace) {
- return;
- }
- if(b) {
- this.css(this.CB['play'], 'display', 'none');
- this.css(this.CB['pauseCenter'], 'display', 'none');
- this.css(this.CB['pause'], 'display', 'block');
- } else {
- this.css(this.CB['play'], 'display', 'block');
- if(this.css(this.CB['errorText'], 'display') == 'none') {
- this.css(this.CB['pauseCenter'], 'display', 'block');
- } else {
- this.css(this.CB['pauseCenter'], 'display', 'none');
- }
- this.css(this.CB['pause'], 'display', 'none');
- }
- },
- /*
- 内部函数
- 监听seek结束
- */
- seekedHandler: function() {
- this.resetTrack();
- this.isTimeButtonMove = true;
- if(this.V.paused) {
- this.videoPlay();
- }
- },
- /*
- 内部函数
- 监听播放结束
- */
- endedHandler: function() {
- if(!this.vars['loop']) {
- this.videoPause();
- }
- },
- /*
- 内部函数
- 监听音量改变
- */
- volumechangeHandler: function() {
- if(!this.showFace) {
- return;
- }
- try {
- if(this.V.volume > 0) {
- this.css(this.CB['mute'], 'display', 'block');
- this.css(this.CB['escMute'], 'display', 'none');
- } else {
- this.css(this.CB['mute'], 'display', 'none');
- this.css(this.CB['escMute'], 'display', 'block');
- }
- } catch(event) {}
- },
- /*
- 内部函数
- 监听播放时间调节进度条
- */
- timeUpdateHandler: function() {
- var duration = 0;
- if(this.playerType == 'html5video') {
- try {
- duration = this.V.duration;
- } catch(event) {}
- }
- if(duration > 0) {
- this.time = this.V.currentTime;
- this.timeTextHandler();
- this.trackShowHandler();
- if(this.isTimeButtonMove) {
- this.timeProgress(this.time, duration);
- }
- }
- },
- /*
- 内部函数
- 按时间改变进度条
- */
- timeProgress: function(time, duration) {
- if(!this.showFace) {
- return;
- }
- var timeProgressBgW = this.CB['timeProgressBg'].offsetWidth;
- var timeBOW = parseInt((time * timeProgressBgW / duration) - (this.CB['timeButton'].offsetWidth * 0.5));
- if(timeBOW > timeProgressBgW - this.CB['timeButton'].offsetWidth) {
- timeBOW = timeProgressBgW - this.CB['timeButton'].offsetWidth;
- }
- if(timeBOW < 0) {
- timeBOW = 0;
- }
- this.css(this.CB['timeProgress'], 'width', timeBOW + 'px');
- this.css(this.CB['timeButton'], 'left', parseInt(timeBOW) + 'px');
- },
- /*
- 内部函数
- 监听播放时间改变时间显示文本框
- */
- timeTextHandler: function() { //显示时间/总时间
- if(!this.showFace) {
- return;
- }
- var duration = this.V.duration;
- var time = this.V.currentTime;
- if(isNaN(duration) || parseInt(duration) < 0.2) {
- duration = this.vars['duration'];
- }
- this.CB['timeText'].innerHTML = this.formatTime(time) + ' / ' + this.formatTime(duration);
- if(this.CB['timeText'].offsetWidth > 0) {
- this.buttonWidth['timeText'] = this.CB['timeText'].offsetWidth;
- }
- },
- /*
- 内部函数
- 监听是否是缓冲状态
- */
- bufferEdHandler: function() {
- if(!this.showFace || this.playerType == 'flashplayer') {
- return;
- }
- var thisTemp = this;
- var clearTimerBuffer = function() {
- if(thisTemp.timerBuffer != null) {
- if(thisTemp.timerBuffer.runing) {
- thisTemp.sendJS('buffer', 100);
- thisTemp.timerBuffer.stop();
- }
- thisTemp.timerBuffer = null;
- }
- };
- clearTimerBuffer();
- var bufferFun = function() {
- if(thisTemp.V.buffered.length > 0) {
- var duration = thisTemp.V.duration;
- var len = thisTemp.V.buffered.length;
- var bufferStart = thisTemp.V.buffered.start(len - 1);
- var bufferEnd = thisTemp.V.buffered.end(len - 1);
- var loadTime = bufferStart + bufferEnd;
- var loadProgressBgW = thisTemp.CB['timeProgressBg'].offsetWidth;
- var timeButtonW = thisTemp.CB['timeButton'].offsetWidth;
- var loadW = parseInt((loadTime * loadProgressBgW / duration) + timeButtonW);
- if(loadW >= loadProgressBgW) {
- loadW = loadProgressBgW;
- clearTimerBuffer();
- }
- thisTemp.changeLoad(loadTime);
- }
- };
- this.timerBuffer = new this.timer(200, bufferFun);
- },
- /*
- 内部函数
- 单独计算加载进度
- */
- changeLoad: function(loadTime) {
- if(this.V == null) {
- return;
- }
- if(!this.showFace) {
- return;
- }
- var loadProgressBgW = this.CB['timeProgressBg'].offsetWidth;
- var timeButtonW = this.CB['timeButton'].offsetWidth;
- var duration = this.V.duration;
- if(this.isUndefined(loadTime)) {
- loadTime = this.loadTime;
- } else {
- this.loadTime = loadTime;
- }
- var loadW = parseInt((loadTime * loadProgressBgW / duration) + timeButtonW);
- this.css(this.CB['loadProgress'], 'width', loadW + 'px');
- },
- /*
- 内部函数
- 判断是否是直播
- */
- judgeIsLive: function() {
- var thisTemp = this;
- if(this.timerError != null) {
- if(this.timerError.runing) {
- this.timerError.stop();
- }
- this.timerError = null;
- }
- this.error = false;
- if(this.showFace) {
- this.css(this.CB['errorText'], 'display', 'none');
- }
- var timeupdate = function(event) {
- thisTemp.timeUpdateHandler();
- };
- if(!this.vars['live']) {
- if(this.V != null && this.playerType == 'html5video') {
- this.addListenerInside('timeupdate', timeupdate);
- thisTemp.timeTextHandler();
- thisTemp.prompt(); //添加提示点
- window.setTimeout(function() {
- thisTemp.bufferEdHandler();
- }, 200);
- }
- } else {
- this.removeListenerInside('timeupdate', timeupdate);
- if(this.timerTime != null) {
- window.clearInterval(this.timerTime);
- timerTime = null;
- }
- if(this.timerTime != null) {
- if(this.timerTime.runing) {
- this.timerTime.stop();
- }
- this.timerTime = null;
- }
- var timeFun = function() {
- if(thisTemp.V != null && !thisTemp.V.paused && thisTemp.showFace) {
- thisTemp.CB['timeText'].innerHTML = thisTemp.getNowDate();
- }
- };
- this.timerTime = new this.timer(1000, timeFun);
- //timerTime.start();
- }
- this.definition();
- },
- /*
- 内部函数
- 加载字幕
- */
- loadTrack: function() {
- if(this.playerType == 'flashplayer' || this.vars['flashplayer'] == true) {
- return;
- }
- var thisTemp = this;
- var track = this.vars['cktrack'];
- var obj = {
- method: 'get',
- dataType: 'text',
- url: track,
- charset: 'utf-8',
- success: function(data) {
- thisTemp.track = thisTemp.parseSrtSubtitles(data);
- thisTemp.trackIndex = 0;
- thisTemp.nowTrackShow = {
- sn: ''
- };
- }
- };
- this.ajax(obj);
- },
- /*
- 内部函数
- 重置字幕
- */
- resetTrack: function() {
- this.trackIndex = 0;
- this.nowTrackShow = {
- sn: ''
- };
- },
- /*
- 内部函数
- 根据时间改变读取显示字幕
- */
- trackShowHandler: function() {
- if(!this.showFace) {
- return;
- }
- if(this.track.length < 1) {
- return;
- }
- if(this.trackIndex >= this.track.length) {
- this.trackIndex = 0;
- }
- var nowTrack = this.track[this.trackIndex]; //当前编号对应的字幕内容
- /*
- this.nowTrackShow=当前显示在界面上的内容
- 如果当前时间正好在nowTrack时间内,则需要判断
- */
- if(this.time >= nowTrack['startTime'] && this.time <= nowTrack['endTime']) {
- /*
- 如果当前显示的内容不等于当前需要显示的内容时,则需要显示正确的内容
- */
- var nowShow = this.nowTrackShow;
- if(nowShow['sn'] != nowTrack['sn']) {
- this.trackHide();
- this.trackShow(nowTrack);
- }
- } else {
- /*
- * 如果当前播放时间不在当前编号字幕内,则需要先清空当前的字幕内容,再显示新的字幕内容
- */
- this.trackHide();
- this.checkTrack();
- }
- },
- /*
- 内部函数
- 显示字幕内容
- */
- trackShow: function(track) {
- this.nowTrackShow = track;
- var arr = track['content'];
- for(var i = 0; i < arr.length; i++) {
- var obj = {
- list: [{
- type: 'text',
- text: arr[i],
- color: '#FFFFFF',
- size: 16,
- font: this.fontFamily,
- lineHeight: 30
- }],
- position: [1, 2, null, -(arr.length - i) * 30 - 50]
- };
- var ele = this.addElement(obj);
- this.trackElement.push(ele);
- }
- },
- /*
- 内部函数
- 隐藏字字幕内容
- */
- trackHide: function() {
- for(var i = 0; i < this.trackElement.length; i++) {
- this.deleteElement(this.trackElement[i]);
- }
- this.trackElement = [];
- },
- /*
- 内部函数
- 重新计算字幕的编号
- */
- checkTrack: function() {
- var num = this.trackIndex;
- var arr = this.track;
- var i = 0;
- for(i = num; i < arr.length; i++) {
- if(this.time >= arr[i]['startTime'] && this.time <= arr[i]['endTime']) {
- this.trackIndex = i;
- break;
- }
- }
- },
- /*
- -----------------------------------------------------------------------------接口函数开始
- 接口函数
- 在播放和暂停之间切换
- */
- playOrPause: function() {
- if(!this.loaded) {
- return;
- }
- if(this.config['videoClick']) {
- if(this.V == null) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.playOrPause();
- return;
- }
- if(this.V.paused) {
- this.videoPlay();
- } else {
- this.videoPause();
- }
- }
- },
- /*
- 接口函数
- 播放动作
- */
- videoPlay: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoPlay();
- return;
- }
- this.V.play();
- },
- /*
- 接口函数
- 暂停动作
- */
- videoPause: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoPause();
- return;
- }
- this.V.pause();
- },
- /*
- 接口函数
- 跳转时间动作
- */
- videoSeek: function(time) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoSeek(time);
- return;
- }
- var meta = this.getMetaDate();
- var duration = meta['duration'];
- if(duration > 0 && time > duration) {
- time = duration;
- }
- if(time >= 0) {
- this.V.currentTime = time;
- this.sendJS('seekTime', time);
- }
- },
- /*
- 接口函数
- 调节音量/获取音量
- */
- changeVolume: function(vol, bg, button) {
- if(this.loaded) {
- if(this.playerType == 'flashplayer') {
- this.V.changeVolume(time);
- return;
- }
- }
- if(isNaN(vol) || this.isUndefined(vol)) {
- vol = 0;
- }
- if(!this.loaded) {
- this.vars['volume'] = vol;
- }
- if(!this.html5Video) {
- this.V.changeVolume(vol);
- return;
- }
- try {
- if(this.isUndefined(bg)) {
- bg = true;
- }
- } catch(e) {}
- try {
- if(this.isUndefined(button)) {
- button = true;
- }
- } catch(e) {}
- if(!vol) {
- vol = 0;
- }
- if(vol < 0) {
- vol = 0;
- }
- if(vol > 1) {
- vol = 1;
- }
- try {
- this.V.volume = vol;
- } catch(error) {}
- this.volume = vol;
- if(bg && this.showFace) {
- var bgW = vol * this.CB['volumeBg'].offsetWidth;
- if(bgW < 0) {
- bgW = 0;
- }
- if(bgW > this.CB['volumeBg'].offsetWidth) {
- bgW = this.CB['volumeBg'].offsetWidth;
- }
- this.css(this.CB['volumeUp'], 'width', bgW + 'px');
- }
- if(button && this.showFace) {
- var buLeft = parseInt(this.CB['volumeUp'].offsetWidth - (this.CB['volumeBO'].offsetWidth * 0.5));
- if(buLeft > this.CB['volumeBg'].offsetWidth - this.CB['volumeBO'].offsetWidth) {
- buLeft = this.CB['volumeBg'].offsetWidth - this.CB['volumeBO'].offsetWidth
- }
- if(buLeft < 0) {
- buLeft = 0;
- }
- this.css(this.CB['volumeBO'], 'left', buLeft + 'px');
- }
- },
- /*
- 接口函数
- 静音
- */
- videoMute: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoMute();
- return;
- }
- this.volumeTemp = this.V ? (this.V.volume > 0 ? this.V.volume : this.vars['volume']) : this.vars['volume'];
- this.changeVolume(0);
- },
- /*
- 接口函数
- 取消静音
- */
- videoEscMute: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoEscMute();
- return;
- }
- this.changeVolume(this.volumeTemp > 0 ? this.volumeTemp : this.vars['volume']);
- },
- /*
- 接口函数
- 快退
- */
- fastBack: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.fastBack();
- return;
- }
- var time = this.time - this.ckplayerConfig['config']['timeJump'];
- if(time < 0) {
- time = 0;
- }
- this.videoSeek(time);
- },
- /*
- 接口函数
- 快进
- */
- fastNext: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.fastNext();
- return;
- }
- var time = this.time + this.ckplayerConfig['config']['timeJump'];
- if(time > this.V.duration) {
- time = this.V.duration;
- }
- this.videoSeek(time);
- },
- /*
- 接口函数
- 获取当前播放的地址
- */
- getCurrentSrc:function(){
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- return this.V.getCurrentSrc();
- }
- return this.V.currentSrc;
- },
- /*
- 内置函数
- 全屏/退出全屏动作,该动作只能是用户操作才可以触发,比如用户点击按钮触发该事件
- */
- switchFull: function() {
- if(this.full) {
- this.quitFullScreen();
- } else {
- this.fullScreen();
- }
- },
- /*
- 内置函数
- 全屏动作,该动作只能是用户操作才可以触发,比如用户点击按钮触发该事件
- */
- fullScreen: function() {
- if(this.html5Video && this.playerType == 'html5video') {
- var element = this.PD;
- if(element.requestFullscreen) {
- element.requestFullscreen();
- } else if(element.mozRequestFullScreen) {
- element.mozRequestFullScreen();
- } else if(element.webkitRequestFullscreen) {
- element.webkitRequestFullscreen();
- } else if(element.msRequestFullscreen) {
- element.msRequestFullscreen();
- } else if(element.oRequestFullscreen) {
- element.oRequestFullscreen();
- }
- this.judgeFullScreen();
- } else {
- //this.V.fullScreen();
- }
- },
- /*
- 接口函数
- 退出全屏动作
- */
- quitFullScreen: function() {
- if(this.html5Video && this.playerType == 'html5video') {
- if(document.exitFullscreen) {
- document.exitFullscreen();
- } else if(document.msExitFullscreen) {
- document.msExitFullscreen();
- } else if(document.mozCancelFullScreen) {
- document.mozCancelFullScreen();
- } else if(document.oRequestFullscreen) {
- document.oCancelFullScreen();
- } else if(document.requestFullscreen) {
- document.requestFullscreen();
- } else if(document.webkitExitFullscreen) {
- document.webkitExitFullscreen();
- } else {
- this.css(document.documentElement, 'cssText', '');
- this.css(document.document.body, 'cssText', '');
- this.css(this.PD, 'cssText', '');
- }
- this.judgeFullScreen();
- }
- },
- /*
- 下面列出只有flashplayer里支持的
- */
- videoRotation: function(n) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoRotation(n);
- return;
- }
- if(this.isUndefined(n)) {
- n = 0;
- }
- var tf = this.css(this.V, 'transform');
- if(this.isUndefined(tf) && !tf) {
- tf = 'rotate(0deg)';
- }
- var reg = tf.match(/rotate\([^)]+\)/);
- reg = reg ? reg[0].replace('rotate(', '').replace('deg)', '') : '';
- if(reg == '') {
- reg = 0;
- } else {
- reg = parseInt(reg);
- }
- if(n == -1) {
- reg -= 90;
- } else if(n == 1) {
- reg += 90;
- } else {
- if(n != 90 && n != 180 && n != 270 && n != -90 && n != -180 && n != -270) {
- reg = 0;
- } else {
- reg = n;
- }
- }
- n = reg;
- tf = tf.replace(/rotate\([^)]+\)/, '') + ' rotate(' + n + 'deg)';
- this.css(this.V, 'transform', tf);
- return;
- },
- videoBrightness: function(n) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoBrightness(n);
- return;
- }
- },
- videoContrast: function(n) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoContrast(n);
- return;
- }
- },
- videoSaturation: function(n) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoSaturation(n);
- return;
- }
- },
- videoHue: function(n) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoHue(n);
- return;
- }
- },
- videoZoom: function(n) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoZoom(n);
- return;
- }
- if(this.isUndefined(n)) {
- n = 1;
- }
- if(n < 0) {
- n = 0;
- }
- if(n > 2) {
- n = 2;
- }
- var tf = this.css(this.V, 'transform');
- tf = tf.replace(/scale\([^)]+\)/, '') + ' scale(' + n + ')';
- this.css(this.V, 'transform', tf);
- return;
- },
- videoProportion: function(w, h) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoProportion(w, h);
- return;
- }
- },
- adPlay: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.adPlay();
- return;
- }
- },
- adPause: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.adPause();
- return;
- }
- },
- videoError: function(n) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoError(n);
- return;
- }
- },
- changeConfig: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.changeConfig(arguments);
- return;
- }
- var obj = this.ckplayerConfig;
- var arg = arguments;
- for(var i = 0; i < arg.length - 1; i++) {
- if(obj.hasOwnProperty(arg[i])) {
- obj = obj[arg[i]];
- } else {
- return;
- }
- }
- var val = arg[arg.length - 1];
- switch(arg.length) {
- case 2:
- this.ckplayerConfig[arg[0]] = val;
- break;
- case 3:
- this.ckplayerConfig[arg[0]][arg[1]] = val;
- break;
- case 4:
- this.ckplayerConfig[arg[0]][arg[1]][arg[2]] = val;
- break;
- case 5:
- this.ckplayerConfig[arg[0]][arg[1]][arg[2]][arg[3]] = val;
- break;
- case 6:
- this.ckplayerConfig[arg[0]][arg[1]][arg[2]][arg[3]][arg[4]] = val;
- break;
- case 7:
- this.ckplayerConfig[arg[0]][arg[1]][arg[2]][arg[3]][arg[4]][arg[5]] = val;
- break;
- case 8:
- this.ckplayerConfig[arg[0]][arg[1]][arg[2]][arg[3]][arg[4]][arg[5]][arg[6]] = val;
- break;
- case 9:
- this.ckplayerConfig[arg[0]][arg[1]][arg[2]][arg[3]][arg[4]][arg[5]][arg[6]][arg[7]] = val;
- break;
- case 10:
- this.ckplayerConfig[arg[0]][arg[1]][arg[2]][arg[3]][arg[4]][arg[5]][arg[6]][arg[7]][arg[8]] = val;
- break;
- default:
- return;
- break;
- }
- this.sendJS('configChange', this.ckplayerConfig);
- },
- custom: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.custom(arguments);
- return;
- }
- },
- getConfig: function() {
- if(!this.loaded) {
- return null;
- }
- if(this.playerType == 'flashplayer') {
- return this.V.getConfig(arguments);
- }
- },
- openUrl: function(n) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.openUrl(n);
- return;
- }
- },
- /*
- 接口函数
- 清除视频
- */
- videoClear: function() {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.videoClear();
- return;
- }
- },
- /*
- 接口函数
- 向播放器传递新的视频地址
- */
- newVideo: function(c) {
- if(this.playerType == 'flashplayer') {
- this.V.newVideo(c);
- return;
- } else {
- this.embed(c);
- }
- },
- /*
- 接口函数
- 截图
- */
- screenshot: function(obj, save, name) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- try {
- this.V.screenshot(obj, save, name);
- } catch(error) {
- this.log(error);
- }
- return;
- }
- if(obj == 'video') {
- var newCanvas = document.createElement('canvas');
- newCanvas.width = this.V.videoWidth;
- newCanvas.height = this.V.videoHeight;
- newCanvas.getContext('2d').drawImage(this.V, 0, 0, this.V.videoWidth, this.V.videoHeight);
- try {
- var base64 = newCanvas.toDataURL('image/jpeg');
- this.sendJS('screenshot', {
- object: obj,
- save: save,
- name: name,
- base64: base64
- });
- } catch(error) {
- this.log(error);
- }
- }
- },
- /*
- 接口函数
- 改变播放器尺寸
- */
- changeSize: function(w, h) {
- if(this.isUndefined(w)) {
- w = 0;
- }
- if(this.isUndefined(h)) {
- h = 0;
- }
- if(w > 0) {
- this.css(this.CD, 'width', w + 'px');
- }
- if(h > 0) {
- this.css(this.CD, 'height', h + 'px');
- }
- if(this.html5Video) {
- this.elementCoordinate();
- }
- },
- /*
- 接口函数
- 改变视频播放速度
- */
- changePlaybackRate: function(n) {
- if(this.html5Video) {
- var arr = this.playbackRateArr;
- n = parseInt(n);
- if(n < arr.length) {
- this.newPlaybackrate(arr[n][1]);
- }
- }
- },
- /*
- 内部函数
- 注册控制控制栏显示与隐藏函数
- */
- changeControlBarShow: function(show) {
- if(!this.loaded) {
- return;
- }
- if(this.playerType == 'flashplayer') {
- this.V.changeControlBarShow(show);
- return;
- }
- if(show) {
- this.controlBarIsShow = true;
- this.controlBarHide(false);
- } else {
- this.controlBarIsShow = false;
- this.controlBarHide(true);
- }
- },
- /*
- -----------------------------------------------------------------------
- 调用flashplayer
- */
- embedSWF: function() {
- var vid = this.randomString();
- var flashvars = this.getFlashVars();
- var param = this.getFlashplayerParam();
- var flashplayerUrl = 'http://www.macromedia.com/go/getflashplayer';
- var html = '',
- src = javascriptPath + 'ckplayer.swf';
- id = 'id="' + vid + '" name="' + vid + '" ';
- html += '<object pluginspage="' + flashplayerUrl + '" classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=11,3,0,0" width="100%" height="100%" ' + id + ' align="middle">';
- html += param['v'];
- html += '<param name="movie" value="' + src + '">';
- html += '<param name="flashvars" value="' + flashvars + '">';
- html += '<embed ' + param['w'] + ' src="' + src + '" flashvars="' + flashvars + '" width="100%" height="100%" ' + id + ' align="middle" type="application/x-shockwave-flash" pluginspage="' + flashplayerUrl + '" />';
- html += '</object>';
- this.PD.innerHTML = html;
- this.V = this.getObjectById(vid); //V:定义播放器对象全局变量
- this.playerType = 'flashplayer';
- //this.loaded=true;
- },
- /*
- 内置函数
- 将vars对象转换成字符
- */
- getFlashVars: function() {
- this.getVarsObject();
- var v = this.vars;
- var z = '';
- for(k in v) {
- if(k != 'flashplayer' && k != 'container' && v[k] != '') {
- if(z != '') {
- z += '&';
- }
- var vk = v[k];
- if(vk == true) {
- vk = 1;
- }
- if(vk == false) {
- vk = 0;
- }
- z += k + '=' + vk;
- }
- }
- if(!v.hasOwnProperty('volume') || !v['volume']) {
- if(z != '') {
- z += '&';
- }
- z += 'volume=0';
- }
- return z;
- },
- /*
- 内置函数
- 将vars格式化成flash能接受的对象。再由getFlashVars函数转化成字符串或由newVideo直接使用
- */
- getVarsObject: function() {
- var v = this.vars;
- var f = '',
- d = '',
- w = ''; //f=视频地址,d=清晰度地址,w=权重,z=最终地址
- var arr = this.VA;
- var prompt = v['promptSpot'];
- var i = 0;
- var video = this.vars['video'];
- if(typeof(video) == 'object') { //对象或数组
- if(!this.isUndefined(typeof(video.length))) { //说明是数组
- var arr = video;
- for(i = 0; i < arr.length; i++) {
- var arr2 = arr[i];
- if(arr2) {
- if(f != '') {
- f += this.ckplayerConfig['config']['split'];
- d += ',';
- w += ',';
- v['type']+=this.ckplayerConfig['config']['split'];
- }
- f += encodeURIComponent(decodeURIComponent(arr2[0]));
- d += arr2[2];
- w += arr2[3];
- v['type']+=arr2[1].replace('video/','');
- }
- }
- } else {
- f = encodeURIComponent(decodeURIComponent(video['file']));
- if(!this.isUndefined(video['type'])) {
- v['type'] = video['type'];
- }
- d = '';
- w = '';
- }
- } else {
- f = encodeURIComponent(decodeURIComponent(video));
- }
- if(v['preview'] != null) {
- v['previewscale'] = v['preview']['scale'];
- v['preview'] = v['preview']['file'].join(',');
- }
- if(prompt != null) {
- v['promptspot'] = '';
- v['promptspottime'] = '';
- for(i = 0; i < prompt.length; i++) {
- if(v['promptspot'] != '') {
- v['promptspot'] += ',';
- v['promptspottime'] += ',';
- }
- v['promptspot'] += prompt[i]['words'];
- v['promptspottime'] += prompt[i]['time'];
- }
- }
- if(f != '') {
- v['video'] = f;
- v['definition'] = d;
- v['weight'] = w;
- }
- if(!v['volume']) {
- v['volume'] = 0;
- }
- var newV = {};
-
- for(var k in v) {
- if(v[k] != null) {
- newV[k] = v[k];
- }
- if(k == 'type') {
- newV[k] = v[k].replace('video/m3u8', 'm3u8');
- }
- }
- this.vars = newV;
- },
- /*
- 内置函数
- 将embedSWF里的param的对象进行转换
- */
- getFlashplayerParam: function() {
- var w = '',
- v = '',
- o = {
- allowScriptAccess: 'always',
- allowFullScreen: true,
- quality: 'high',
- bgcolor: '#000'
- };
- for(var e in o) {
- w += e + '="' + o[e] + '" ';
- v += '<param name="' + e + '" value="' + o[e] + '" />';
- }
- w = w.replace('movie=', 'src=');
- return {
- w: w,
- v: v
- };
- },
- /*
- 操作动作结束
- -----------------------------------------------------------------------
-
- 接口函数
- 获取元数据部分
- */
- getMetaDate: function() {
- if(!this.loaded || this.V == null) {
- return false;
- }
- if(this.playerType == 'html5video') {
- var duration = 0;
- try {
- duration = !isNaN(this.V.duration) ? this.V.duration : 0;
- } catch(event) {this.log(event);}
- var data = {
- duration: duration,
- volume: this.V.volume,
- playbackRate: this.V.playbackRate,
- width: this.PD.offsetWidth || this.V.offsetWidth || this.V.width,
- height: this.PD.offsetHeight || this.V.offsetHeight || this.V.height,
- streamWidth: this.V.videoWidth,
- streamHeight: this.V.videoHeight,
- videoWidth: this.V.offsetWidth,
- videoHeight: this.V.offsetHeight,
- paused: this.V.paused
- };
- return data;
- } else {
- try{
- return this.V.getMetaDate();
- }
- catch(event){
- this.log(event);
- }
- }
- return false;
- },
- /*
- 接口函数
- 取当前提供给播放器播放的视频列表
- */
- getVideoUrl: function() {
- if(this.playerType == 'flashplayer') {
- return this.V.getVideoUrl();
- }
- var arr = [];
- if(this.V.src) {
- arr.push(this.V.src);
- } else {
- var uArr = this.V.childNodes;
- for(var i = 0; i < uArr.length; i++) {
- arr.push(uArr[i].src);
- }
- }
- return arr;
- },
- /*
- 内置函数
- 格式化函数
- */
- clickEvent: function(call) {
- if(call == 'none' || call == '' || call == null) {
- return {
- type: 'none'
- };
- }
- var callArr = call.split('->');
- var type = '',
- fun = '',
- link = '',
- target = '';
- if(callArr.length == 2) {
- var callM = callArr[0];
- var callE = callArr[1];
- if(!callE) {
- return {
- type: 'none'
- };
- }
- var val = '';
- var eArr = [];
- type = callM;
- switch(callM) {
- case 'actionScript':
- //trace(THIS.hasOwnProperty(callE));
- if(callE.indexOf('(') > -1) {
- eArr = callE.split('(');
- callE = eArr[0];
- val = eArr[1].replace(')', '');
- }
- if(val == '') {
- fun = 'thisTemp.' + callE + '()';
- } else {
- fun = 'thisTemp.' + callE + '(' + val + ')';
- }
- break;
- case 'javaScript':
- if(callE.substr(0, 11) == '[flashvars]') {
- callE = callE.substr(11);
- if(this.vars.hasOwnProperty(callE)) {
- callE = this.vars[callE];
- } else {
- break;
- }
- }
- if(callE.indexOf('(') > -1) {
- eArr = callE.split('(');
- callE = eArr[0];
- val = eArr[1].replace(')', '');
- }
- if(val == '') {
- fun = callE + '()';
- } else {
- fun = callE + '(' + val + ')';
- }
- break;
- case "link":
- var callLink = (callE + ',').split(',');
- if(callLink[0].substr(0, 11) == '[flashvars]') {
- var fl = callLink[0].replace('[flashvars]', '');
- if(this.vars.hasOwnProperty(fl)) {
- callLink[0] = this.vars[fl];
- } else {
- break;
- }
- }
- if(!callLink[1]) {
- callLink[1] = '_blank';
- }
- link = callLink[0];
- target = callLink[1];
- break;
- }
- }
- return {
- type: type,
- fun: fun,
- link: link,
- target: target
- }
- },
- /*
- 内置函数
- 向播放器界面添加一个文本
- */
- addElement: function(attribute) {
- var thisTemp = this;
- if(this.playerType == 'flashplayer') {
- return this.V.addElement(attribute);
- }
- var i = 0;
- var obj = {
- list: null,
- x: '100%',
- y: "50%",
- position: null,
- alpha: 1,
- backgroundColor: '',
- backAlpha: 1,
- backRadius: 0,
- clickEvent: ''
- };
- obj = this.standardization(obj, attribute);
- var list = obj['list'];
- if(list == null) {
- return '';
- }
- var id = 'element' + this.randomString(10);
- var ele = document.createElement('div');
- ele.className = id;
- if(obj['x']) {
- ele.setAttribute('data-x', obj['x']);
- }
- if(obj['y']) {
- ele.setAttribute('data-y', obj['y']);
- }
- if(obj['position'] != null) {
- ele.setAttribute('data-position', obj['position'].join(','));
- }
- this.PD.appendChild(ele);
- var eid = this.getByElement(id);
- this.css(eid, {
- position: 'absolute',
- filter: 'alpha(opacity:' + obj['alpha'] + ')',
- opacity: obj['alpha'].toString(),
- width: '800px',
- zIndex: '20'
- });
- var bgid = 'elementbg' + this.randomString(10);
- var bgAlpha = obj['alpha'].toString();
- var bgColor = obj['backgroundColor'].replace('0x', '#');
- var html = '';
- var idArr = [];
- var clickArr = [];
- if(!this.isUndefined(list) && list.length > 0) {
- var textObj, returnObj, clickEvent;
- for(i = 0; i < list.length; i++) {
- var newEleid = 'elementnew' + this.randomString(10);
- switch(list[i]['type']) {
- case 'image':
- case 'png':
- case 'jpg':
- case 'jpeg':
- case 'gif':
- textObj = {
- type: 'image',
- file: '',
- radius: 0, //圆角弧度
- width: 30, //定义宽,必需要定义
- height: 30, //定义高,必需要定义
- alpha: 1, //透明度
- paddingLeft: 0, //左边距离
- paddingRight: 0, //右边距离
- paddingTop: 0,
- paddingBottom: 0,
- marginLeft: 0,
- marginRight: 0,
- marginTop: 0,
- marginBottom: 0,
- backgroundColor: '',
- clickEvent: ''
- };
- list[i] = this.standardization(textObj, list[i]);
- clickEvent = this.clickEvent(list[i]['clickEvent']);
- clickArr.push(clickEvent);
- if(clickEvent['type'] == 'link') {
- html += '<div class="' + newEleid + '" data-i="' + i + '"><a href="' + clickEvent['link'] + '" target="' + clickEvent['target'] + '"><img class="' + newEleid + '_image" src="' + list[i]['file'] + '" style="border:0;"></a></div>';
- } else {
- html += '<div class="' + newEleid + '" data-i="' + i + '"><img class="' + newEleid + '_image" src="' + list[i]['file'] + '" style="border:0;"></div>';
- }
- break;
- case 'text':
- textObj = {
- type: 'text', //说明是文本
- text: '', //文本内容
- color: '0xFFFFFF',
- size: 14,
- font: this.fontFamily,
- leading: 0,
- alpha: 1, //透明度
- paddingLeft: 0, //左边距离
- paddingRight: 0, //右边距离
- paddingTop: 0,
- paddingBottom: 0,
- marginLeft: 0,
- marginRight: 0,
- marginTop: 0,
- marginBottom: 0,
- backgroundColor: '',
- backAlpha: 1,
- backRadius: 0, //背景圆角弧度,支持数字统一设置,也支持分开设置[30,20,20,50],对应上左,上右,下右,下左
- clickEvent: ''
- };
- list[i] = this.standardization(textObj, list[i]);
- clickEvent = this.clickEvent(list[i]['clickEvent']);
- clickArr.push(clickEvent);
- if(clickEvent['type'] == 'link') {
- html += '<div class="' + newEleid + '" data-i="' + i + '"><div class="' + newEleid + '_bg"></div><div class="' + newEleid + '_text"><a href="' + clickEvent['link'] + '" target="' + clickEvent['target'] + '">' + list[i]['text'] + '</a></div></div>';
- } else {
- html += '<div class="' + newEleid + '" data-i="' + i + '"><div class="' + newEleid + '_bg"></div><div class="' + newEleid + '_text">' + list[i]['text'] + '</div></div>';
- }
- break;
- default:
- break;
- }
- idArr.push(newEleid);
- }
- }
- var objClickEvent = this.clickEvent(obj['clickEvent']);
- /*if(objClickEvent['type']=='link'){
- html = '<a href="'+objClickEvent['link']+'" target="'+objClickEvent['target']+'">' + html + '</a>';
- }*/
- eid.innerHTML = '<div class="' + bgid + '"></div><div class="' + bgid + '_c">' + html + '</div>';
- if(objClickEvent['type'] == 'javaScript' || objClickEvent['type'] == 'actionScript') {
- var objClickHandler = function() {
- eval(objClickEvent['fun']);
- thisTemp.sendJS('clickEvent', clk['type'] + '->' + clk['fun'].replace('thisTemp.', '').replace('()', ''));
- };
- this.addListenerInside('click', objClickHandler, this.getByElement(bgid + '_c'))
- }
- this.css(bgid + '_c', {
- position: 'absolute',
- zIndex: '2'
- });
- for(i = 0; i < idArr.length; i++) {
- var clk = clickArr[i];
- if(clk['type'] == 'javaScript' || clk['type'] == 'actionScript') {
- var clickHandler = function() {
- clk = clickArr[this.getAttribute('data-i')];
- eval(clk['fun']);
- thisTemp.sendJS('clickEvent', clk['type'] + '->' + clk['fun'].replace('thisTemp.', '').replace('()', ''));
- };
- this.addListenerInside('click', clickHandler, this.getByElement(idArr[i]))
- }
- switch(list[i]['type']) {
- case 'image':
- case 'png':
- case 'jpg':
- case 'jpeg':
- case 'gif':
- this.css(idArr[i], {
- float: 'left',
- width: list[i]['width'] + 'px',
- height: list[i]['height'] + 'px',
- filter: 'alpha(opacity:' + list[i]['alpha'] + ')',
- opacity: list[i]['alpha'].toString(),
- marginLeft: list[i]['marginLeft'] + 'px',
- marginRight: list[i]['marginRight'] + 'px',
- marginTop: list[i]['marginTop'] + 'px',
- marginBottom: list[i]['marginBottom'] + 'px',
- borderRadius: list[i]['radius'] + 'px',
- cursor: 'pointer'
- });
- this.css(idArr[i] + '_image', {
- width: list[i]['width'] + 'px',
- height: list[i]['height'] + 'px',
- borderRadius: list[i]['radius'] + 'px'
- });
- break;
- case 'text':
- this.css(idArr[i] + '_text', {
- filter: 'alpha(opacity:' + list[i]['alpha'] + ')',
- opacity: list[i]['alpha'].toString(),
- borderRadius: list[i]['radius'] + 'px',
- fontFamily: list[i]['font'],
- fontSize: list[i]['size'] + 'px',
- color: list[i]['color'].replace('0x', '#'),
- lineHeight: list[i]['leading'] > 0 ? list[i]['leading'] + 'px' : '',
- paddingLeft: list[i]['paddingLeft'] + 'px',
- paddingRight: list[i]['paddingRight'] + 'px',
- paddingTop: list[i]['paddingTop'] + 'px',
- paddingBottom: list[i]['paddingBottom'] + 'px',
- whiteSpace: 'nowrap',
- position: 'absolute',
- zIndex: '3',
- cursor: 'pointer'
- });
- this.css(idArr[i], {
- float: 'left',
- width: this.getByElement(idArr[i] + '_text').offsetWidth + 'px',
- height: this.getByElement(idArr[i] + '_text').offsetHeight + 'px',
- marginLeft: list[i]['marginLeft'] + 'px',
- marginRight: list[i]['marginRight'] + 'px',
- marginTop: list[i]['marginTop'] + 'px',
- marginBottom: list[i]['marginBottom'] + 'px'
- });
- this.css(idArr[i] + '_bg', {
- width: this.getByElement(idArr[i] + '_text').offsetWidth + 'px',
- height: this.getByElement(idArr[i] + '_text').offsetHeight + 'px',
- filter: 'alpha(opacity:' + list[i]['backAlpha'] + ')',
- opacity: list[i]['backAlpha'].toString(),
- borderRadius: list[i]['backRadius'] + 'px',
- backgroundColor: list[i]['backgroundColor'].replace('0x', '#'),
- position: 'absolute',
- zIndex: '2'
- });
- break;
- default:
- break;
- }
- }
- this.css(bgid, {
- width: this.getByElement(bgid + '_c').offsetWidth + 'px',
- height: this.getByElement(bgid + '_c').offsetHeight + 'px',
- position: 'absolute',
- filter: 'alpha(opacity:' + bgAlpha + ')',
- opacity: bgAlpha,
- backgroundColor: bgColor.replace('0x', '#'),
- borderRadius: obj['backRadius'] + 'px',
- zIndex: '1'
- });
- this.css(eid, {
- width: this.getByElement(bgid).offsetWidth + 'px',
- height: this.getByElement(bgid).offsetHeight + 'px'
- });
- var eidCoor = this.calculationCoor(eid);
- this.css(eid, {
- left: eidCoor['x'] + 'px',
- top: eidCoor['y'] + 'px'
- });
- this.elementArr.push(eid.className);
- return eid;
- },
- /*
- 内置函数
- 获取元件的属性,包括x,y,width,height,alpha
- */
- getElement: function(element) {
- if(this.playerType == 'flashplayer') {
- return this.V.getElement(element);
- }
- var ele = element;
- if(typeof(element) == 'string') {
- ele = this.getByElement(element);
- }
- var coor = this.getCoor(ele);
- return {
- x: coor['x'],
- y: coor['y'],
- width: ele.offsetWidth,
- height: ele.offsetHeight,
- alpha: !this.isUndefined(this.css(ele, 'opacity')) ? parseFloat(this.css(ele, 'opacity')) : 1
- };
- },
- /*
- 内置函数
- 根据节点的x,y计算在播放器里的坐标
- */
- calculationCoor: function(ele) {
- if(this.playerType == 'flashplayer') {
- return this.V.calculationCoor(ele);
- }
- if(ele == []) {
- return;
- }
- var x, y, position = [];
- var w = this.PD.offsetWidth,
- h = this.PD.offsetHeight;
- var ew = ele.offsetWidth,
- eh = ele.offsetHeight;
- if(!this.isUndefined(this.getDataset(ele, 'x'))) {
- x = this.getDataset(ele, 'x');
- }
- if(!this.isUndefined(this.getDataset(ele, 'y'))) {
- y = this.getDataset(ele, 'y');
- }
- if(!this.isUndefined(this.getDataset(ele, 'position'))) {
- try{
- position = this.getDataset(ele, 'position').toString().split(',');
- }
- catch(event){}
- }
- if(position.length > 0) {
- position.push(null, null, null, null);
- var i = 0;
- for(i = 0; i < position.length; i++) {
- if(this.isUndefined(position[i]) || position[i] == null || position[i] == 'null' || position[i] == '') {
- position[i] = null;
- } else {
- position[i] = parseFloat(position[i]);
- }
- }
- if(position[2] == null) {
- switch(position[0]) {
- case 0:
- x = 0;
- break;
- case 1:
- x = parseInt((w - ew) * 0.5);
- break;
- default:
- x = w - ew;
- break;
- }
- } else {
- switch(position[0]) {
- case 0:
- x = position[2];
- break;
- case 1:
- x = parseInt(w * 0.5) + position[2];
- break;
- default:
- x = w + position[2];
- break;
- }
- }
- if(position[3] == null) {
- switch(position[1]) {
- case 0:
- y = 0;
- break;
- case 1:
- y = parseInt((h - eh) * 0.5);
- break;
- default:
- y = h - eh;
- break;
- }
- } else {
- switch(position[1]) {
- case 0:
- y = position[3];
- break;
- case 1:
- y = parseInt(h * 0.5) + position[3];
- break;
- default:
- y = h + position[3];
- break;
- }
- }
- } else {
- if(x.substring(x.length - 1, x.length) == '%') {
- x = Math.floor(parseInt(x.substring(0, x.length - 1)) * w * 0.01);
- }
- if(y.substring(y.length - 1, y.length) == '%') {
- y = Math.floor(parseInt(y.substring(0, y.length - 1)) * h * 0.01);
- }
- }
- return {
- x: x,
- y: y
- }
- },
- /*
- 内置函数
- 修改新增元件的坐标
- */
- changeElementCoor: function() {
- for(var i = 0; i < this.elementArr.length; i++) {
- if(this.getByElement(this.elementArr[i]) != []) {
- var c = this.calculationCoor(this.getByElement(this.elementArr[i]));
- if(c['x'] && c['y']){
- this.css(this.elementArr[i], {
- top: c['y'] + 'px',
- left: c['x'] + 'px'
- });
- }
- }
- }
- },
- /*
- 内置函数
- 缓动效果集
- */
- tween: function() {
- var Tween = {
- None: { //均速运动
- easeIn: function(t, b, c, d) {
- return c * t / d + b;
- },
- easeOut: function(t, b, c, d) {
- return c * t / d + b;
- },
- easeInOut: function(t, b, c, d) {
- return c * t / d + b;
- }
- },
- Quadratic: {
- easeIn: function(t, b, c, d) {
- return c * (t /= d) * t + b;
- },
- easeOut: function(t, b, c, d) {
- return -c * (t /= d) * (t - 2) + b;
- },
- easeInOut: function(t, b, c, d) {
- if((t /= d / 2) < 1) return c / 2 * t * t + b;
- return -c / 2 * ((--t) * (t - 2) - 1) + b;
- }
- },
- Cubic: {
- easeIn: function(t, b, c, d) {
- return c * (t /= d) * t * t + b;
- },
- easeOut: function(t, b, c, d) {
- return c * ((t = t / d - 1) * t * t + 1) + b;
- },
- easeInOut: function(t, b, c, d) {
- if((t /= d / 2) < 1) return c / 2 * t * t * t + b;
- return c / 2 * ((t -= 2) * t * t + 2) + b;
- }
- },
- Quartic: {
- easeIn: function(t, b, c, d) {
- return c * (t /= d) * t * t * t + b;
- },
- easeOut: function(t, b, c, d) {
- return -c * ((t = t / d - 1) * t * t * t - 1) + b;
- },
- easeInOut: function(t, b, c, d) {
- if((t /= d / 2) < 1) return c / 2 * t * t * t * t + b;
- return -c / 2 * ((t -= 2) * t * t * t - 2) + b;
- }
- },
- Quintic: {
- easeIn: function(t, b, c, d) {
- return c * (t /= d) * t * t * t * t + b;
- },
- easeOut: function(t, b, c, d) {
- return c * ((t = t / d - 1) * t * t * t * t + 1) + b;
- },
- easeInOut: function(t, b, c, d) {
- if((t /= d / 2) < 1) return c / 2 * t * t * t * t * t + b;
- return c / 2 * ((t -= 2) * t * t * t * t + 2) + b;
- }
- },
- Sine: {
- easeIn: function(t, b, c, d) {
- return -c * Math.cos(t / d * (Math.PI / 2)) + c + b;
- },
- easeOut: function(t, b, c, d) {
- return c * Math.sin(t / d * (Math.PI / 2)) + b;
- },
- easeInOut: function(t, b, c, d) {
- return -c / 2 * (Math.cos(Math.PI * t / d) - 1) + b;
- }
- },
- Exponential: {
- easeIn: function(t, b, c, d) {
- return(t == 0) ? b : c * Math.pow(2, 10 * (t / d - 1)) + b;
- },
- easeOut: function(t, b, c, d) {
- return(t == d) ? b + c : c * (-Math.pow(2, -10 * t / d) + 1) + b;
- },
- easeInOut: function(t, b, c, d) {
- if(t == 0) return b;
- if(t == d) return b + c;
- if((t /= d / 2) < 1) return c / 2 * Math.pow(2, 10 * (t - 1)) + b;
- return c / 2 * (-Math.pow(2, -10 * --t) + 2) + b;
- }
- },
- Circular: {
- easeIn: function(t, b, c, d) {
- return -c * (Math.sqrt(1 - (t /= d) * t) - 1) + b;
- },
- easeOut: function(t, b, c, d) {
- return c * Math.sqrt(1 - (t = t / d - 1) * t) + b;
- },
- easeInOut: function(t, b, c, d) {
- if((t /= d / 2) < 1) return -c / 2 * (Math.sqrt(1 - t * t) - 1) + b;
- return c / 2 * (Math.sqrt(1 - (t -= 2) * t) + 1) + b;
- }
- },
- Elastic: {
- easeIn: function(t, b, c, d, a, p) {
- if(t == 0) return b;
- if((t /= d) == 1) return b + c;
- if(!p) p = d * .3;
- if(!a || a < Math.abs(c)) {
- a = c;
- var s = p / 4;
- } else var s = p / (2 * Math.PI) * Math.asin(c / a);
- return -(a * Math.pow(2, 10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p)) + b;
- },
- easeOut: function(t, b, c, d, a, p) {
- if(t == 0) return b;
- if((t /= d) == 1) return b + c;
- if(!p) p = d * .3;
- if(!a || a < Math.abs(c)) {
- a = c;
- var s = p / 4;
- } else var s = p / (2 * Math.PI) * Math.asin(c / a);
- return(a * Math.pow(2, -10 * t) * Math.sin((t * d - s) * (2 * Math.PI) / p) + c + b);
- },
- easeInOut: function(t, b, c, d, a, p) {
- if(t == 0) return b;
- if((t /= d / 2) == 2) return b + c;
- if(!p) p = d * (.3 * 1.5);
- if(!a || a < Math.abs(c)) {
- a = c;
- var s = p / 4;
- } else var s = p / (2 * Math.PI) * Math.asin(c / a);
- if(t < 1) return -.5 * (a * Math.pow(2, 10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p)) + b;
- return a * Math.pow(2, -10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p) * .5 + c + b;
- }
- },
- Back: {
- easeIn: function(t, b, c, d, s) {
- if(s == undefined) s = 1.70158;
- return c * (t /= d) * t * ((s + 1) * t - s) + b;
- },
- easeOut: function(t, b, c, d, s) {
- if(s == undefined) s = 1.70158;
- return c * ((t = t / d - 1) * t * ((s + 1) * t + s) + 1) + b;
- },
- easeInOut: function(t, b, c, d, s) {
- if(s == undefined) s = 1.70158;
- if((t /= d / 2) < 1) return c / 2 * (t * t * (((s *= (1.525)) + 1) * t - s)) + b;
- return c / 2 * ((t -= 2) * t * (((s *= (1.525)) + 1) * t + s) + 2) + b;
- }
- },
- Bounce: {
- easeIn: function(t, b, c, d) {
- return c - Tween.Bounce.easeOut(d - t, 0, c, d) + b;
- },
- easeOut: function(t, b, c, d) {
- if((t /= d) < (1 / 2.75)) {
- return c * (7.5625 * t * t) + b;
- } else if(t < (2 / 2.75)) {
- return c * (7.5625 * (t -= (1.5 / 2.75)) * t + .75) + b;
- } else if(t < (2.5 / 2.75)) {
- return c * (7.5625 * (t -= (2.25 / 2.75)) * t + .9375) + b;
- } else {
- return c * (7.5625 * (t -= (2.625 / 2.75)) * t + .984375) + b;
- }
- },
- easeInOut: function(t, b, c, d) {
- if(t < d / 2) return Tween.Bounce.easeIn(t * 2, 0, c, d) * .5 + b;
- else return Tween.Bounce.easeOut(t * 2 - d, 0, c, d) * .5 + c * .5 + b;
- }
- }
- };
- return Tween;
- },
- /*
- 接口函数
- 缓动效果
- ele:Object=需要缓动的对象,
- parameter:String=需要改变的属性:x,y,width,height,alpha,
- effect:String=效果名称,
- start:Int=起始值,
- end:Int=结束值,
- speed:Number=运动的总秒数,支持小数
- */
- animate: function(attribute) {
- if(this.playerType == 'flashplayer') {
- return this.V.animate(attribute);
- }
- var thisTemp = this;
- var animateId = 'animate_' + this.randomString();
- var obj = {
- element: null,
- parameter: 'x',
- static: false,
- effect: 'None.easeIn',
- start: null,
- end: null,
- speed: 0,
- overStop: false,
- pauseStop: false, //暂停播放时缓动是否暂停
- callBack: null
- };
- obj = this.standardization(obj, attribute);
- if(obj['element'] == null || obj['speed'] == 0) {
- return false;
- }
- var w = this.PD.offsetWidth,
- h = this.PD.offsetHeight;
- var effArr = (obj['effect'] + '.').split('.');
- var tweenFun = this.tween()[effArr[0]][effArr[1]];
- var eleCoor = {
- x: 0,
- y: 0
- };
- if(this.isUndefined(tweenFun)) {
- return false;
- }
- //先将该元件从元件数组里删除,让其不再跟随播放器的尺寸改变而改变位置
- var def = this.arrIndexOf(this.elementArr, obj['element'].className);
- if(def > -1) {
- this.elementArr.splice(def, 1);
- }
- //var run = true;
- var css = {};
- //对传递的参数进行转化,x和y转化成left,top
- var pm = this.getElement(obj['element']); //包含x,y,width,height,alpha属性
- var t = 0; //当前时间
- var b = 0; //初始值
- var c = 0; //变化量
- var d = obj['speed'] * 1000; //持续时间
- var timerTween = null;
- var tweenObj = null;
- var start = obj['start'] == null ? '' : obj['start'].toString();
- var end = obj['end'] == null ? '' : obj['end'].toString();
- switch(obj['parameter']) {
- case 'x':
- if(obj['start'] == null) {
- b = pm['x'];
- } else {
- if(start.substring(start.length - 1, start.length) == '%') {
- b = parseInt(start) * w * 0.01;
- } else {
- b = parseInt(start);
- }
- }
- if(obj['end'] == null) {
- c = pm['x'] - b;
- } else {
- if(end.substring(end.length - 1, end.length) == '%') {
- c = parseInt(end) * w * 0.01 - b;
- } else if(end.substring(0, 1) == '-' || end.substring(0, 1) == '+') {
- if(typeof(obj['end']) == 'number') {
- c = parseInt(obj['end']) - b;
- } else {
- c = parseInt(end);
- }
- } else {
- c = parseInt(end) - b;
- }
- }
- break;
- case 'y':
- if(obj['start'] == null) {
- b = pm['y'];
- } else {
- if(start.substring(start.length - 1, start.length) == '%') {
- b = parseInt(start) * h * 0.01;
- } else {
- b = parseInt(start);
- }
- }
- if(obj['end'] == null) {
- c = pm['y'] - b;
- } else {
- if(end.substring(end.length - 1, end.length) == '%') {
- c = parseInt(end) * h * 0.01 - b;
- } else if(end.substring(0, 1) == '-' || end.substring(0, 1) == '+') {
- if(typeof(obj['end']) == 'number') {
- c = parseInt(obj['end']) - b;
- } else {
- c = parseInt(end);
- }
- } else {
- c = parseInt(end) - b;
- }
- }
- break;
- case 'alpha':
- if(obj['start'] == null) {
- b = pm['alpha'] * 100;
- } else {
- if(start.substring(start.length - 1, start.length) == '%') {
- b = parseInt(obj['start']);
- } else {
- b = parseInt(obj['start'] * 100);
- }
- }
- if(obj['end'] == null) {
- c = pm['alpha'] * 100 - b;
- } else {
- if(end.substring(end.length - 1, end.length) == '%') {
- c = parseInt(end) - b;
- } else if(end.substring(0, 1) == '-' || end.substring(0, 1) == '+') {
- if(typeof(obj['end']) == 'number') {
- c = parseInt(obj['end']) * 100 - b;
- } else {
- c = parseInt(obj['end']) * 100;
- }
- } else {
- c = parseInt(obj['end']) * 100 - b;
- }
- }
- break;
- }
- var callBack = function() {
- var index = thisTemp.arrIndexOf(thisTemp.animateElementArray, animateId);
- if(index > -1) {
- thisTemp.animateArray.splice(index, 1);
- thisTemp.animateElementArray.splice(index, 1);
- }
- index = thisTemp.arrIndexOf(thisTemp.animatePauseArray, animateId);
- if(index > -1) {
- thisTemp.animatePauseArray.splice(index, 1);
- }
- if(obj['callBack'] != null && obj['element'] && obj['callBack'] != 'callBack' && obj['callBack'] != 'tweenX' && obj['tweenY'] != 'callBack' && obj['callBack'] != 'tweenAlpha') {
- var cb = eval(obj['callBack']);
- cb(obj['element']);
- obj['callBack'] = null;
- }
- };
- var stopTween = function() {
- if(timerTween != null) {
- if(timerTween.runing) {
- timerTween.stop();
- }
- timerTween = null;
- }
- };
- var tweenX = function() {
- if(t < d) {
- t += 10;
- css = {
- left: Math.ceil(tweenFun(t, b, c, d)) + 'px'
- };
- if(obj['static']) {
- eleCoor = thisTemp.calculationCoor(obj['element']);
- css['top'] = eleCoor['y'] + 'px';
- }
- thisTemp.css(obj['element'], css);
- } else {
- stopTween();
- thisTemp.elementArr.push(obj['element'].className);
- callBack();
- }
- };
- var tweenY = function() {
- if(t < d) {
- t += 10;
- css = {
- top: Math.ceil(tweenFun(t, b, c, d)) + 'px'
- };
- if(obj['static']) {
- eleCoor = thisTemp.calculationCoor(obj['element']);
- css['left'] = eleCoor['x'] + 'px';
- }
- thisTemp.css(obj['element'], css);
- } else {
- stopTween();
- thisTemp.elementArr.push(obj['element'].className);
- callBack();
- }
- };
- var tweenAlpha = function() {
- if(t < d) {
- t += 10;
- eleCoor = thisTemp.calculationCoor(obj['element']);
- var ap = Math.ceil(tweenFun(t, b, c, d)) * 0.01;
- css = {
- filter: 'alpha(opacity:' + ap + ')',
- opacity: ap.toString()
- };
- if(obj['static']) {
- eleCoor = thisTemp.calculationCoor(obj['element']);
- css['top'] = eleCoor['y'] + 'px';
- css['left'] = eleCoor['x'] + 'px';
- }
- thisTemp.css(obj['element'], css);
- } else {
- stopTween();
- thisTemp.elementArr.push(obj['element'].className);
- callBack();
- }
- };
- switch(obj['parameter']) {
- case 'x':
- tweenObj = tweenX;
- break;
- case 'y':
- tweenObj = tweenY;
- break;
- case 'alpha':
- tweenObj = tweenAlpha;
- break;
- default:
- break;
- }
- timerTween = new thisTemp.timer(10, tweenObj);
- timerTween.callBackFunction=callBack;
- if(obj['overStop']) {
- var mouseOver = function() {
- if(timerTween != null && timerTween.runing) {
- timerTween.stop();
- }
- };
- this.addListenerInside('mouseover', mouseOver, obj['element']);
- var mouseOut = function() {
- var start = true;
- if(obj['pauseStop'] && thisTemp.getMetaDate()['paused']) {
- start = false;
- }
- if(timerTween != null && !timerTween.runing && start) {
- timerTween.start();
- }
- };
- this.addListenerInside('mouseout', mouseOut, obj['element']);
- }
- this.animateArray.push(timerTween);
- this.animateElementArray.push(animateId);
- if(obj['pauseStop']) {
- this.animatePauseArray.push(animateId);
- }
- return animateId;
- },
- /*
- 接口函数函数
- 继续运行animate
- */
- animateResume: function(id) {
- if(this.playerType == 'flashplayer') {
- this.V.animateResume(this.isUndefined(id) ? '' : id);
- return;
- }
- var arr = [];
- if(id != '' && !this.isUndefined(id) && id != 'pause') {
- arr.push(id);
- } else {
- if(id === 'pause') {
- arr = this.animatePauseArray;
- } else {
- arr = this.animateElementArray;
- }
- }
- for(var i = 0; i < arr.length; i++) {
- var index = this.arrIndexOf(this.animateElementArray, arr[i]);
- if(index > -1) {
- this.animateArray[index].start();
- }
- }
- },
- /*
- 接口函数
- 暂停运行animate
- */
- animatePause: function(id) {
- if(this.playerType == 'flashplayer') {
- this.V.animatePause(this.isUndefined(id) ? '' : id);
- return;
- }
- var arr = [];
- if(id != '' && !this.isUndefined(id) && id != 'pause') {
- arr.push(id);
- } else {
- if(id === 'pause') {
- arr = this.animatePauseArray;
- } else {
- arr = this.animateElementArray;
- }
- }
- for(var i = 0; i < arr.length; i++) {
- var index = this.arrIndexOf(this.animateElementArray, arr[i]);
- if(index > -1) {
- this.animateArray[index].stop();
- }
- }
- },
- /*
- 内置函数
- 根据ID删除数组里对应的内容
- */
- deleteAnimate: function(id) {
- if(this.playerType == 'flashplayer' && this.V) {
- try {
- this.V.deleteAnimate(id);
- } catch(event) {this.log(event);}
- return;
- }
- //console.log(this.animateElementArray)
- var index = this.arrIndexOf(this.animateElementArray, id);
- if(index > -1) {
- this.animateArray[index].callBackFunction();
- this.animateArray.splice(index, 1);
- this.animateElementArray.splice(index, 1);
- }
- },
- /*
- 内置函数
- 删除外部新建的元件
- */
- deleteElement: function(ele) {
- if(this.playerType == 'flashplayer' && this.V) {
- try {
- this.V.deleteElement(ele);
- } catch(event) {}
- return;
- }
- //先将该元件从元件数组里删除,让其不再跟随播放器的尺寸改变而改变位置
- var def = this.arrIndexOf(this.elementArr, ele.className);
- if(def > -1) {
- this.elementArr.splice(def, 1);
- }
- this.deleteAnimate(ele);
- this.deleteChild(ele);
- },
- /*
- --------------------------------------------------------------
- 共用函数部分
- 以下函数并非只能在本程序中使用,也可以在页面其它项目中使用
- 根据ID获取元素对象
- */
- getByElement: function(obj, parent) {
- if(this.isUndefined(parent)) {
- parent = document;
- }
- var num = obj.substr(0, 1);
- var res = [];
- if(num != '#') {
- if(num == '.') {
- obj = obj.substr(1, obj.length);
- }
- if(parent.getElementsByClassName) {
- res = parent.getElementsByClassName(obj);
- } else {
- var reg = new RegExp(' ' + obj + ' ', 'i');
- var ele = parent.getElementsByTagName('*');
- for(var i = 0; i < ele.length; i++) {
- if(reg.test(' ' + ele[i].className + ' ')) {
- res.push(ele[i]);
- }
- }
- }
- if(res.length > 0) {
- return res[0];
- } else {
- return res;
- }
- } else {
- if(num == '#') {
- obj = obj.substr(1, obj.length);
- }
- return document.getElementById(obj);
- }
- },
- /*
- 共用函数
- 功能:修改样式或获取指定样式的值,
- elem:ID对象或ID对应的字符,如果多个对象一起设置,则可以使用数组
- attribute:样式名称或对象,如果是对象,则省略掉value值
- value:attribute为样式名称时,定义的样式值
- 示例一:
- this.css(ID,'width','100px');
- 示例二:
- this.css('id','width','100px');
- 示例三:
- this.css([ID1,ID2,ID3],'width','100px');
- 示例四:
- this.css(ID,{
- width:'100px',
- height:'100px'
- });
- 示例五(获取宽度):
- var width=this.css(ID,'width');
- */
- css: function(elem, attribute, value) {
- var i = 0;
- var k = '';
- if(typeof(elem) == 'object') { //对象或数组
- if(!this.isUndefined(typeof(elem.length))) { //说明是数组
- for(i = 0; i < elem.length; i++) {
- var el;
- if(typeof(elem[i]) == 'string') {
- el = this.getByElement(elem[i])
- } else {
- el = elem[i];
- }
- if(typeof(attribute) != 'object') {
- if(!this.isUndefined(value)) {
- el.style[attribute] = value;
- }
- } else {
- for(k in attribute) {
- if(!this.isUndefined(attribute[k])) {
- el.style[k] = attribute[k];
- }
- }
- }
- }
- return;
- }
- }
- if(typeof(elem) == 'string') {
- elem = this.getByElement(elem);
- }
- if(typeof(attribute) != 'object') {
- if(!this.isUndefined(value)) {
- elem.style[attribute] = value;
- } else {
- if(!this.isUndefined(this.getStyle(elem, attribute))) {
- return this.getStyle(elem, attribute);
- } else {
- return false;
- }
- }
- } else {
- for(k in attribute) {
- if(!this.isUndefined(attribute[k])) {
- elem.style[k] = attribute[k];
- }
- }
- }
- },
- /*
- 内置函数
- 兼容型获取style
- */
- getStyle: function(obj, attr) {
- if(!this.isUndefined(obj.style[attr])) {
- return obj.style[attr];
- } else {
- if(obj.currentStyle) {
- return obj.currentStyle[attr];
- } else {
- return getComputedStyle(obj, false)[attr];
- }
- }
- },
- /*
- 共用函数
- 判断变量是否存在或值是否为undefined
- */
- isUndefined: function(value) {
- try {
- if(value == 'undefined' || value == undefined) {
- return true;
- }
- } catch(event) {this.log(event);}
- return false;
- },
- /*
- 共用函数
- 外部监听函数
- */
- addListener: function(name, funName) {
- if(name && funName) {
- if(this.playerType == 'flashplayer') {
- var ff = ''; //定义用来向flashplayer传递的函数字符
- if(typeof(funName) == 'function') {
- ff = this.getParameterNames(funName);
- }
- this.V.addListener(name, ff);
- return;
- }
- var have = false;
- for(var i = 0; i < this.listenerJsArr.length; i++) {
- var arr = this.listenerJsArr[i];
- if(arr[0] == name && arr[1] == funName) {
- have = true;
- break;
- }
- }
- if(!have) {
- this.listenerJsArr.push([name, funName]);
- }
- }
- },
- /*
- 共用函数
- 外部删除监听函数
- */
- removeListener: function(name, funName) {
- if(name && funName) {
- if(this.playerType == 'flashplayer') {
- var ff = ''; //定义用来向flashplayer传递的函数字符
- if(typeof(funName) == 'function') {
- ff = this.getParameterNames(funName);
- }
- this.V.removeListener(name, ff);
- return;
- }
- for(var i = 0; i < this.listenerJsArr.length; i++) {
- var arr = this.listenerJsArr[i];
- if(arr[0] == name && arr[1] == funName) {
- this.listenerJsArr.splice(i, 1);
- break;
- }
- }
- }
- },
- /*
- 内部监听函数,调用方式:
- this.addListenerInside('click',function(event){},[ID]);
- d值为空时,则表示监听当前的视频播放器
- */
- addListenerInside: function(e, f, d, t) {
- if(this.isUndefined(t)) {
- t = false;
- }
- var o = this.V;
- if(!this.isUndefined(d)) {
- o = d;
- }
- if(o.addEventListener) {
- try {
- o.addEventListener(e, f, t);
- } catch(event) {}
- } else if(o.attachEvent) {
- try {
- o.attachEvent('on' + e, f);
- } catch(event) {}
- } else {
- o['on' + e] = f;
- }
- },
- /*
- 删除内部监听函数,调用方式:
- this.removeListenerInside('click',function(event){}[,ID]);
- d值为空时,则表示监听当前的视频播放器
- */
- removeListenerInside: function(e, f, d, t) {
- /*if(this.playerType=='flashplayer' && this.getParameterNames(f) && this.isUndefined(d)) {
- return;
- }*/
- if(this.isUndefined(t)) {
- t = false;
- }
- var o = this.V;
- if(!this.isUndefined(d)) {
- o = d;
- }
- if(o.removeEventListener) {
- try {
- this.addNum--;
- o.removeEventListener(e, f, t);
- } catch(e) {}
- } else if(o.detachEvent) {
- try {
- o.detachEvent('on' + e, f);
- } catch(e) {}
- } else {
- o['on' + e] = null;
- }
- },
- /*
- 共用函数
- 统一分配监听,以达到跟as3同样效果
- */
- sendJS: function(name, val) {
- var list = this.listenerJsArr;
- var obj = {
- variable: this.vars['variable']
- };
- if(this.vars['playerID']) {
- obj['playerID'] = this.vars['playerID'];
- }
- for(var i = 0; i < list.length; i++) {
- var arr = list[i];
- if(arr[0] == name) {
- if(val) {
- switch(arr[1].length) {
- case 1:
- arr[1](val);
- break;
- case 2:
- arr[1](val, obj);
- break;
- default:
- arr[1]();
- break;
- }
- } else {
- switch(arr[1].length) {
- case 1:
- arr[1](obj);
- break;
- default:
- arr[1]();
- break;
- }
- }
- }
- }
- },
- /*
- 共用函数
- 获取函数名称,如 function ckplayer(){} var fun=ckplayer,则getParameterNames(fun)=ckplayer
- */
- getParameterNames: function(fn) {
- if(typeof(fn) !== 'function') {
- return false;
- }
- var COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg;
- var code = fn.toString().replace(COMMENTS, '');
- var result = code.slice(code.indexOf(' ') + 1, code.indexOf('('));
- return result === null ? false : result;
- },
- /*
- 共用函数
- 获取当前本地时间
- */
- getNowDate: function() {
- var nowDate = new Date();
- var month = nowDate.getMonth() + 1;
- var date = nowDate.getDate();
- var hours = nowDate.getHours();
- var minutes = nowDate.getMinutes();
- var seconds = nowDate.getSeconds();
- var tMonth = '',
- tDate = '',
- tHours = '',
- tMinutes = '',
- tSeconds = '',
- tSeconds = (seconds < 10) ? '0' + seconds : seconds + '',
- tMinutes = (minutes < 10) ? '0' + minutes : minutes + '',
- tHours = (hours < 10) ? '0' + hours : hours + '',
- tDate = (date < 10) ? '0' + date : date + '',
- tMonth = (month < 10) ? '0' + month : month + '';
- return tMonth + '/' + tDate + ' ' + tHours + ':' + tMinutes + ':' + tSeconds;
- },
- /*
- 共用函数
- 格式化时分秒
- seconds:Int:秒数
- ishours:Boolean:是否显示小时,如果设置成false,则会显示如80:20,表示1小时20分钟20秒
- */
- formatTime: function(seconds, ishours) {
- var tSeconds = '',
- tMinutes = '',
- tHours = '';
- if(isNaN(seconds)) {
- seconds = 0;
- }
- var s = Math.floor(seconds % 60),
- m = 0,
- h = 0;
- if(ishours) {
- m = Math.floor(seconds / 60) % 60;
- h = Math.floor(seconds / 3600);
- } else {
- m = Math.floor(seconds / 60);
- }
- tSeconds = (s < 10) ? '0' + s : s + '';
- tMinutes = (m > 0) ? ((m < 10) ? '0' + m + ':' : m + ':') : '00:';
- tHours = (h > 0) ? ((h < 10) ? '0' + h + ':' : h + ':') : '';
- if(ishours) {
- return tHours + tMinutes + tSeconds;
- } else {
- return tMinutes + tSeconds;
- }
- },
- /*
- 共用函数
- 获取一个随机字符
- len:随机字符长度
- */
- randomString: function(len) {
- len = len || 16;
- var chars = 'abcdefghijklmnopqrstuvwxyz';
- var maxPos = chars.length;
- var val = '';
- for(i = 0; i < len; i++) {
- val += chars.charAt(Math.floor(Math.random() * maxPos));
- }
- return 'ch' + val;
- },
- /*
- 共用函数
- 获取字符串长度,中文算两,英文数字算1
- */
- getStringLen: function(str) {
- var len = 0;
- for(var i = 0; i < str.length; i++) {
- if(str.charCodeAt(i) > 127 || str.charCodeAt(i) == 94) {
- len += 2;
- } else {
- len++;
- }
- }
- return len;
- },
- /*
- 内部函数
- 用来为ajax提供支持
- */
- createXHR: function() {
- if(window.XMLHttpRequest) {
- //IE7+、Firefox、Opera、Chrome 和Safari
- return new XMLHttpRequest();
- } else if(window.ActiveXObject) {
- //IE6 及以下
- try {
- return new ActiveXObject('Microsoft.XMLHTTP');
- } catch(event) {
- try {
- return new ActiveXObject('Msxml2.XMLHTTP');
- } catch(event) {
- this.eject(this.errorList[7]);
- }
- }
- } else {
- this.eject(this.errorList[8]);
- }
- },
- /*
- 共用函数
- ajax调用
- */
- ajax: function(cObj) {
- var thisTemp = this;
- var callback = null;
- var obj = {
- method: 'get', //请求类型
- dataType: 'json', //请求的数据类型
- charset: 'utf-8',
- async: false, //true表示异步,false表示同步
- url: '',
- data: null,
- success: null
- };
- if(typeof(cObj) != 'object') {
- this.eject(this.errorList[9]);
- return;
- }
- obj = this.standardization(obj, cObj);
- if(obj.dataType === 'json' || obj.dataType === 'text' || obj.dataType === 'html') {
- var xhr = this.createXHR();
- callback = function() {
- //判断http的交互是否成功
- if(xhr.status == 200) {
- if(obj.success == null) {
- return;
- }
- if(obj.dataType === 'json') {
- try {
- obj.success(eval('(' + xhr.responseText + ')')); //回调传递参数
- } catch(event) {
- obj.success(null);
- }
- } else {
- obj.success(xhr.responseText); //回调传递参数
- }
- } else {
- thisTemp.eject(thisTemp.errorList[10], 'Ajax.status:' + xhr.status);
- }
- };
- obj.url = obj.url + '?rand=' + this.randomString(6);
- obj.data = this.formatParams(obj.data); //通过params()将名值对转换成字符串
- if(obj.method === 'get' && !this.isUndefined(obj.data)) {
- obj.url += obj.url.indexOf('?') == -1 ? '?' + obj.data : '&' + obj.data;
- }
- if(obj.async === true) { //true表示异步,false表示同步
- xhr.onreadystatechange = function() {
- if(xhr.readyState == 4) { //判断对象的状态是否交互完成
- callback(); //回调
- }
- };
- }
- xhr.open(obj.method, obj.url, obj.async);
- if(obj.method === 'post') {
- xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
- xhr.setRequestHeader('charset', obj['charset']);
- xhr.send(obj.data);
- } else {
- xhr.send(null); //get方式则填null
- }
- if(obj.async === false) { //同步
- callback();
- }
- } else if(obj.dataType === 'jsonp') {
- var oHead = document.getElementsByTagName('head')[0];
- var oScript = document.createElement('script');
- var callbackName = 'callback' + new Date().getTime();
- var params = this.formatParams(obj.data) + '&callback=' + callbackName; //按时间戳拼接字符串
- callback = obj.success;
- //拼接好src
- oScript.src = obj.url.split('?') + '?' + params;
- //插入script标签
- oHead.insertBefore(oScript, oHead.firstChild);
- //jsonp的回调函数
- window[callbackName] = function(json) {
- callback(json);
- oHead.removeChild(oScript);
- };
- }
- },
- /*
- 内置函数
- 动态加载js
- */
- loadJs: function(path, success) {
- var oHead = document.getElementsByTagName('HEAD').item(0);
- var oScript = document.createElement('script');
- oScript.type = 'text/javascript';
- oScript.src = this.getNewUrl(path);
- oHead.appendChild(oScript);
- oScript.onload = function() {
- success();
- }
- },
- /*
- 共用函数
- 排除IE6-9
- */
- isMsie: function() {
- var browser = navigator.appName;
- var b_version = navigator.appVersion;
- var version = b_version.split(';');
- var trim_Version = '';
- if(version.length > 1) {
- trim_Version = version[1].replace(/[ ]/g, '');
- }
- if(browser == 'Microsoft Internet Explorer' && (trim_Version == 'MSIE6.0' || trim_Version == 'MSIE7.0' || trim_Version == 'MSIE8.0' || trim_Version == 'MSIE9.0' || trim_Version == 'MSIE10.0')) {
- return false;
- }
- return true;
- },
- /*
- 共用函数
- 判断是否安装了flashplayer
- */
- uploadFlash: function() {
- var swf;
- if(navigator.userAgent.indexOf('MSIE') > 0) {
- try {
- var swf = new ActiveXObject('ShockwaveFlash.ShockwaveFlash');
- return true;
- } catch(e) {
- return false;
- }
- }
- if(navigator.userAgent.indexOf('Firefox') > 0) {
- swf = navigator.plugins['Shockwave Flash'];
- if(swf) {
- return true
- } else {
- return false;
- }
- }
- return true;
- },
- /*
- 共用函数
- 检测浏览器是否支持HTML5-Video
- */
- supportVideo: function() {
- if(!this.isMsie()) {
- return false;
- }
- if(!!document.createElement('video').canPlayType) {
- var vidTest = document.createElement('video');
- var oggTest;
- try {
- oggTest = vidTest.canPlayType('video/ogg; codecs="theora, vorbis"');
- } catch(error) {
- oggTest = false;
- }
- if(!oggTest) {
- var h264Test;
- try {
- h264Test = vidTest.canPlayType('video/mp4; codecs="avc1.42E01E, mp4a.40.2"');
- } catch(error) {
- h264Test = false;
- }
- if(!h264Test) {
- return false;
- } else {
- if(h264Test == "probably") {
- return true;
- } else {
- return false;
- }
- }
- } else {
- if(oggTest == "probably") {
- return true;
- } else {
- return false;
- }
- }
- } else {
- return false;
- }
- },
- /*
- 共用函数
- 获取属性值
- */
- getDataset: function(ele, z) {
- try {
- return ele.dataset[z];
- } catch(error) {
- try {
- return ele.getAttribute('data-' + z)
- } catch(error) {
- return false;
- }
- }
- },
- /*
- 共用函数
- 返回flashplayer的对象
- */
- getObjectById: function(id) {
- var x = null;
- var y = this.getByElement('#' + id);
- var r = 'embed';
- if(y && y.nodeName == 'OBJECT') {
- if(typeof(y.SetVariable) != 'undefined') {
- x = y;
- } else {
- var z = y.getElementsByTagName(r)[0];
- if(z) {
- x = z;
- }
- }
- }
- return x;
- },
- /*
- 共用函数
- 对象转地址字符串
- */
- formatParams: function(data) {
- var arr = [];
- for(var i in data) {
- arr.push(encodeURIComponent(i) + '=' + encodeURIComponent(data[i]));
- }
- return arr.join('&');
- },
- /*
- 内置函数
- 对地址进行冒泡排序
- */
- arrSort: function(arr) {
- var temp = [];
- for(var i = 0; i < arr.length; i++) {
- for(var j = 0; j < arr.length - i; j++) {
- if(!this.isUndefined(arr[j + 1]) && arr[j][3] < arr[j + 1][3]) {
- temp = arr[j + 1];
- arr[j + 1] = arr[j];
- arr[j] = temp;
- }
- }
- }
- return arr;
- },
- /*
- 内置函数
- 判断文件后缀
- */
- getFileExt: function(filepath) {
- if(filepath != '' && !this.isUndefined(filepath)) {
- if(filepath.indexOf('?') > -1) {
- filepath = filepath.split('?')[0];
- }
- var pos = '.' + filepath.replace(/.+\./, '');
- return pos;
- }
- return '';
- },
- /*
- 内置函数
- 判断是否是移动端
- */
- isMobile: function() {
- if(navigator.userAgent.match(/(iPhone|iPad|iPod|Android|ios)/i)) {
- return true;
- }
- return false;
- },
- /*
- 内置函数
- 搜索字符串str是否包含key
- */
- isContains: function(str, key) {
- return str.indexOf(key) > -1;
- },
- /*
- 内置函数
- 给地址添加随机数
- */
- getNewUrl: function(url) {
- if(this.isContains(url, '?')) {
- return url += '&' + this.randomString(8) + '=' + this.randomString(8);
- } else {
- return url += '?' + this.randomString(8) + '=' + this.randomString(8);
- }
- },
- /*
- 共用函数
- 获取clientX和clientY
- */
- client: function(event) {
- var eve = event || window.event;
- if(this.isUndefined(eve)) {
- eve = {
- clientX: 0,
- clientY: 0
- };
- }
- return {
- x: eve.clientX + (document.documentElement.scrollLeft || this.body.scrollLeft) - this.pdCoor['x'],
- y: eve.clientY + (document.documentElement.scrollTop || this.body.scrollTop) - this.pdCoor['y']
- }
- },
- /*
- 内置函数
- 获取节点的绝对坐标
- */
- getCoor: function(obj) {
- var coor = this.getXY(obj);
- return {
- x: coor['x'] - this.pdCoor['x'],
- y: coor['y'] - this.pdCoor['y']
- };
- },
- getXY: function(obj) {
- var parObj = obj;
- var left = obj.offsetLeft;
- var top = obj.offsetTop;
- while(parObj = parObj.offsetParent) {
- left += parObj.offsetLeft;
- top += parObj.offsetTop;
- }
- return {
- x: left,
- y: top
- };
- },
- /*
- 内置函数
- 删除本对象的所有属性
- */
- removeChild: function() {
- if(this.playerType == 'html5video') {
- //删除计时器
- var i = 0;
- var timerArr = [this.timerError, this.timerFull, this.timerTime, this.timerBuffer, this.timerClick, this.timerLoading, this.timerCBar, this.timerVCanvas];
- for(i = 0; i < timerArr.length; i++) {
- if(timerArr[i] != null) {
- if(timerArr[i].runing) {
- timerArr[i].stop();
- }
- timerArr[i] = null;
- }
- }
- //删除事件监听
- var ltArr = this.listenerJsArr;
- for(i = 0; i < ltArr.length; i++) {
- this.removeListener(ltArr[i][0], ltArr[i][1]);
- }
- }
- this.playerType == '';
- this.V = null;
- if(this.showFace) {
- this.deleteChild(this.CB['menu']);
- }
- this.deleteChild(this.PD);
- this.CD.innerHTML = '';
- },
- /*
- 内置函数
- 画封闭的图形
- */
- canvasFill: function(name, path) {
- name.beginPath();
- for(var i = 0; i < path.length; i++) {
- var d = path[i];
- if(i > 0) {
- name.lineTo(d[0], d[1]);
- } else {
- name.moveTo(d[0], d[1]);
- }
- }
- name.closePath();
- name.fill();
- },
- /*
- 内置函数
- 画矩形
- */
- canvasFillRect: function(name, path) {
- for(var i = 0; i < path.length; i++) {
- var d = path[i];
- name.fillRect(d[0], d[1], d[2], d[3]);
- }
- },
- /*
- 共用函数
- 删除容器节点
- */
- deleteChild: function(f) {
- var def = this.arrIndexOf(this.elementArr, f.className);
- if(def > -1) {
- this.elementArr.splice(def, 1);
- }
- var childs = f.childNodes;
- for(var i = childs.length - 1; i >= 0; i--) {
- f.removeChild(childs[i]);
- }
- if(f && f != null && f.parentNode) {
- try {
- if(f.parentNode) {
- f.parentNode.removeChild(f);
- }
- } catch(event) {}
- }
- },
- /*
- 内置函数
- 根据容器的宽高,内部节点的宽高计算出内部节点的宽高及坐标
- */
- getProportionCoor: function(stageW, stageH, vw, vh) {
- var w = 0,
- h = 0,
- x = 0,
- y = 0;
- if(stageW / stageH < vw / vh) {
- w = stageW;
- h = w * vh / vw;
- } else {
- h = stageH;
- w = h * vw / vh;
- }
- x = (stageW - w) * 0.5;
- y = (stageH - h) * 0.5;
- return {
- width: parseInt(w),
- height: parseInt(h),
- x: parseInt(x),
- y: parseInt(y)
- };
- },
- /*
- 共用函数
- 将字幕文件内容转换成数组
- */
- parseSrtSubtitles: function(srt) {
- var subtitles = [];
- var textSubtitles = [];
- var i = 0;
- var arrs = srt.split('\n');
- var arr = [];
- var delHtmlTag = function(str) {
- return str.replace(/<[^>]+>/g, ''); //去掉所有的html标记
- };
- for(i = 0; i < arrs.length; i++) {
- if(arrs[i].replace(/\s/g, '').length > 0) {
- arr.push(arrs[i]);
- } else {
- if(arr.length > 0) {
- textSubtitles.push(arr);
- }
- arr = [];
- }
- }
- for(i = 0; i < textSubtitles.length; ++i) {
- var textSubtitle = textSubtitles[i];
- if(textSubtitle.length >= 2) {
- var sn = textSubtitle[0]; // 字幕的序号
- var startTime = this.toSeconds(this.trim(textSubtitle[1].split(' --> ')[0])); // 字幕的开始时间
- var endTime = this.toSeconds(this.trim(textSubtitle[1].split(' --> ')[1])); // 字幕的结束时间
- var content = [delHtmlTag(textSubtitle[2])]; // 字幕的内容
- // 字幕可能有多行
- if(textSubtitle.length > 2) {
- for(var j = 3; j < textSubtitle.length; j++) {
- content.push(delHtmlTag(textSubtitle[j]));
- }
- }
- // 字幕对象
- var subtitle = {
- sn: sn,
- startTime: startTime,
- endTime: endTime,
- content: content
- };
- subtitles.push(subtitle);
- }
- }
- return subtitles;
- },
- /*
- 共用函数
- 计时器,该函数模拟as3中的timer原理
- time:计时时间,单位:毫秒
- fun:接受函数
- number:运行次数,不设置则无限运行
- */
- timer: function(time, fun, number) {
- var thisTemp = this;
- this.time = 10; //运行间隔
- this.fun = null; //监听函数
- this.timeObj = null; //setInterval对象
- this.number = 0; //已运行次数
- this.numberTotal = null; //总至需要次数
- this.runing = false; //当前状态
- this.startFun = function() {
- thisTemp.number++;
- thisTemp.fun();
- if(thisTemp.numberTotal != null && thisTemp.number >= thisTemp.numberTotal) {
- thisTemp.stop();
- }
- };
- this.start = function() {
- if(!thisTemp.runing) {
- thisTemp.runing = true;
- thisTemp.timeObj = window.setInterval(thisTemp.startFun, time);
- }
- };
- this.stop = function() {
- if(thisTemp.runing) {
- thisTemp.runing = false;
- window.clearInterval(thisTemp.timeObj);
- thisTemp.timeObj = null;
- }
- };
- if(time) {
- this.time = time;
- }
- if(fun) {
- this.fun = fun;
- }
- if(number) {
- this.numberTotal = number;
- }
- this.start();
- },
- /*
- 共用函数
- 将时分秒转换成秒
- */
- toSeconds: function(t) {
- var s = 0.0;
- if(t) {
- var p = t.split(':');
- for(i = 0; i < p.length; i++) {
- s = s * 60 + parseFloat(p[i].replace(',', '.'));
- }
- }
- return s;
- },
- /*
- 共用函数
- 将对象Object标准化
- */
- standardization: function(o, n) { //n替换进o
- var h = {};
- var k;
- for(k in o) {
- h[k] = o[k];
- }
- for(k in n) {
- var type = typeof(h[k]);
- switch(type) {
- case 'number':
- h[k] = parseFloat(n[k]);
- break;
- default:
- h[k] = n[k];
- break;
- }
- }
- return h;
- },
- /*
- 共用函数
- 搜索数组
- */
- arrIndexOf: function(arr, key) {
- var re = new RegExp(key, ['']);
- return(arr.toString().replace(re, '┢').replace(/[^,┢]/g, '')).indexOf('┢');
- },
- /*
- 共用函数
- 去掉空格
- */
- trim: function(str) {
- if(str!=''){
- return str.replace(/(^\s*)|(\s*$)/g, '');
- }
- return '';
- },
- /*
- 共用函数
- 输出内容到控制台
- */
- log: function(val) {
- try {
- console.log(val);
- } catch(e) {}
- },
- /*
- 共用函数
- 弹出提示
- */
- eject: function(er, val) {
- if(!this.vars['debug']) {
- return;
- }
- var errorVal = er[1];
- if(!this.isUndefined(val)) {
- errorVal = errorVal.replace('[error]', val);
- }
- var value = 'error ' + er[0] + ':' + errorVal;
- try {
- this.log(value);
- } catch(e) {}
- }
- };
- window.ckplayer = ckplayer;
- })();
|