Advertisement
Guest User

GHW GHR [Edit by Street]

a guest
Nov 20th, 2014
191
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 19.61 KB | None | 0 0
  1. //#define engine
  2.  
  3. #include <amxmodx>
  4. #include <amxmisc>
  5. #include <fun>
  6. #if defined engine
  7. #include <engine>
  8. #else
  9. #include <fakemeta>
  10. #endif
  11.  
  12. #define ADMIN_RESERVATION ADMIN_LEVEL_C
  13.  
  14. //Used for Grab
  15. new maxplayers
  16. new grab[33]
  17. new Float:grab_totaldis[33]
  18. new grab_speed_cvar
  19. new grab_enabled_cvar
  20. new bool:has_grab[33]
  21.  
  22. //Used for Hook
  23. new bool:hook[33]
  24. new hook_to[33][3]
  25. new hook_speed_cvar
  26. new hook_enabled_cvar
  27. new bool:has_hook[33]
  28.  
  29. //Used for Rope
  30. new bool:rope[33]
  31. new rope_to[33][3]
  32. new Float:rope_totaldis[33]
  33. new rope_speed_cvar
  34. new rope_enabled_cvar
  35. new bool:has_rope[33]
  36.  
  37. //Used for All
  38. new beamsprite
  39.  
  40.  
  41. /****************************
  42. Register Commands and CVARs
  43. ****************************/
  44.  
  45. public plugin_init()
  46. {
  47. register_plugin("Grab + Hook + Rope","1.0","GHW_Chronic")
  48. register_concmd("+grab","grab_on", ADMIN_RESERVATION," - Use: bind key +grab")
  49. register_concmd("-grab","grab_off")
  50. register_concmd("grab_toggle","grab_toggle", ADMIN_RESERVATION,"Toggles your grab on and off")
  51. register_concmd("+hook","hook_on", ADMIN_RESERVATION," - Use: bind key +hook")
  52. register_concmd("-hook","hook_off")
  53. register_concmd("hook_toggle","hook_toggle", ADMIN_RESERVATION,"Toggles your hook on and off")
  54. register_concmd("+rope","rope_on", ADMIN_RESERVATION," - Use: bind key +rope")
  55. register_concmd("-rope","rope_off")
  56. register_concmd("rope_toggle","rope_toggle", ADMIN_RESERVATION,"Toggles your rope on and off")
  57.  
  58. register_concmd("amx_give_grab","cmd_givetake", ADMIN_RESERVATION,"Give a player the ability to grab <nick>")
  59. register_concmd("amx_give_hook","cmd_givetake", ADMIN_RESERVATION,"Give a player the ability to hook <nick>")
  60. register_concmd("amx_give_rope","cmd_givetake", ADMIN_RESERVATION,"Give a player the ability to rope <nick>")
  61.  
  62. register_concmd("amx_take_grab","cmd_givetake", ADMIN_RESERVATION,"Take a player's ability to grab <nick>")
  63. register_concmd("amx_take_hook","cmd_givetake", ADMIN_RESERVATION,"Take a player's ability to hook <nick>")
  64. register_concmd("amx_take_rope","cmd_givetake", ADMIN_RESERVATION,"Take a player's ability to rope <nick>")
  65.  
  66. register_concmd("amx_ghr_menu","menu_cmd", ADMIN_RESERVATION,"Shows a menu that allows you to turn on/off non-admin use of grab, hook, or rope")
  67.  
  68. register_menucmd(register_menuid("ghr_menu"),(1<<0)|(1<<1)|(1<<2)|(1<<9), "Pressedghr")
  69.  
  70. grab_speed_cvar = register_cvar("grab_speed","5")
  71. grab_enabled_cvar = register_cvar("grab_enabled","0")
  72.  
  73. hook_speed_cvar = register_cvar("hook_speed","5")
  74. hook_enabled_cvar = register_cvar("hook_enabled","0")
  75.  
  76. rope_speed_cvar = register_cvar("rope_speed","5")
  77. rope_enabled_cvar = register_cvar("rope_enabled","0")
  78.  
  79. maxplayers = get_maxplayers()
  80.  
  81. //CVAR that is only used for tracking servers that use this plugin.
  82. register_cvar("GHW_GHW","1",FCVAR_SERVER)
  83. }
  84.  
  85.  
  86. /**********************************
  87. Register beam sprite + Hook Sound
  88. **********************************/
  89.  
  90. public plugin_precache()
  91. {
  92. beamsprite = precache_model("sprites/dot.spr")
  93. precache_sound("weapons/xbow_hit2.wav")
  94. precache_sound("weapons/xbow_fire1.wav")
  95. }
  96.  
  97.  
  98. /*****************************
  99. Reset VARs on client connect
  100. *****************************/
  101.  
  102. public client_putinserver(id)
  103. {
  104. has_grab[id]=false
  105. has_hook[id]=false
  106. has_rope[id]=false
  107. }
  108.  
  109.  
  110. /*****
  111. Menu
  112. *****/
  113.  
  114. public menu_cmd(id,level,cid)
  115. {
  116. if(cmd_access(id,level,cid,1))
  117. {
  118. show_ghr(id)
  119. console_print(id,"[AMXX] Menu launched.")
  120. }
  121. }
  122.  
  123. public show_ghr(id)
  124. {
  125. static aaa[32]
  126. static bbb[32]
  127. static ccc[32]
  128. if(get_pcvar_num(grab_enabled_cvar)==0) format(aaa,31,"No")
  129. else format(aaa,31,"Yes")
  130. if(get_pcvar_num(hook_enabled_cvar)==0) format(bbb,31,"No")
  131. else format(bbb,31,"Yes")
  132. if(get_pcvar_num(rope_enabled_cvar)==0) format(ccc,31,"No")
  133. else format(ccc,31,"Yes")
  134.  
  135. new menuBody[576]
  136.  
  137. if(colored_menus())
  138. {
  139. new len = format(menuBody,575,"\bAllow Players To Use:^n^n")
  140. len += format(menuBody[len],575-len, "\w1. Grab\R\w%s^n",aaa)
  141. len += format(menuBody[len],575-len, "\w2. Hook\R\w%s^n",bbb)
  142. len += format(menuBody[len],575-len, "\w3. Rope\R\w%s^n",ccc)
  143. len += format(menuBody[len],575-len, "\r0. Exit")
  144. }
  145. else
  146. {
  147. new len = format(menuBody,575,"Allow Players To Use:^n^n")
  148. len += format(menuBody[len],575-len, "1. Grab\R%s^n",aaa)
  149. len += format(menuBody[len],575-len, "2. Hook\R%s^n",bbb)
  150. len += format(menuBody[len],575-len, "3. Rope\R%s^n",ccc)
  151. len += format(menuBody[len],575-len, "0. Exit")
  152. }
  153. show_menu(id,(1<<0)|(1<<1)|(1<<2)|(1<<9),menuBody,-1,"ghr_menu")
  154.  
  155. return PLUGIN_CONTINUE
  156. }
  157.  
  158. public Pressedghr(id,key)
  159. {
  160. switch(key)
  161. {
  162. case 0:
  163. {
  164. if(get_pcvar_num(grab_enabled_cvar)==0)
  165. {
  166. set_pcvar_num(grab_enabled_cvar,1)
  167. client_print(0,print_chat,"[AMXX] Admin has enabled Grab for all clients. Use: bind key +grab")
  168. }
  169. else
  170. {
  171. set_pcvar_num(grab_enabled_cvar,0)
  172. client_print(0,print_chat,"[AMXX] Admin has disabled Grab for all non-admins.")
  173. }
  174. show_ghr(id)
  175. }
  176. case 1:
  177. {
  178. if(get_pcvar_num(hook_enabled_cvar)==0)
  179. {
  180. set_pcvar_num(hook_enabled_cvar,1)
  181. client_print(0,print_chat,"[AMXX] Admin has enabled Hook for all clients. Use: bind key +hook")
  182. }
  183. else
  184. {
  185. set_pcvar_num(hook_enabled_cvar,0)
  186. client_print(0,print_chat,"[AMXX] Admin has disabled Hook for all non-admins.")
  187. }
  188. show_ghr(id)
  189. }
  190. case 2:
  191. {
  192. if(get_pcvar_num(rope_enabled_cvar)==0)
  193. {
  194. set_pcvar_num(rope_enabled_cvar,1)
  195. client_print(0,print_chat,"[AMXX] Admin has enabled Rope for all clients. Use: bind key +rope")
  196. }
  197. else
  198. {
  199. set_pcvar_num(rope_enabled_cvar,0)
  200. client_print(0,print_chat,"[AMXX] Admin has disabled Rope for all non-admins.")
  201. }
  202. show_ghr(id)
  203. }
  204. }
  205. }
  206.  
  207.  
  208. /****************
  209. Handle Commands
  210. ****************/
  211.  
  212. public cmd_givetake(id,level,cid)
  213. {
  214. if(!cmd_access(id,level,cid,2))
  215. {
  216. return PLUGIN_HANDLED
  217. }
  218.  
  219. new arg1[32]
  220. read_argv(1,arg1,31)
  221.  
  222. new target = cmd_target(id,arg1,9)
  223. if(!target)
  224. {
  225. return PLUGIN_HANDLED
  226. }
  227.  
  228. new name[32]
  229. get_user_name(target,name,31)
  230. if(get_user_flags(target) & ADMIN_RESERVATION)
  231. {
  232. console_print(id,"[AMXX] Cannot give/take grab/hook/rope from admin %s.",name)
  233. return PLUGIN_HANDLED
  234. }
  235.  
  236. new arg0[32]
  237. read_argv(0,arg0,31)
  238. if(containi(arg0,"give")!=-1)
  239. {
  240. if(containi(arg0,"grab")!=-1)
  241. {
  242. if(has_grab[target])
  243. {
  244. console_print(id,"[AMXX] %s already has grab",name)
  245. }
  246. else
  247. {
  248. has_grab[target]=true
  249. console_print(id,"[AMXX] %s has been given grab",name)
  250. client_print(target,print_chat,"[AMXX] An admin has given you grab. Use: bind key +grab")
  251. }
  252. }
  253. else if(containi(arg0,"hook")!=-1)
  254. {
  255. if(has_hook[target])
  256. {
  257. console_print(id,"[AMXX] %s already has hook",name)
  258. }
  259. else
  260. {
  261. has_hook[target]=true
  262. console_print(id,"[AMXX] %s has been given hook",name)
  263. client_print(target,print_chat,"[AMXX] An admin has given you hook. Use: bind key +hook")
  264. }
  265. }
  266. else if(containi(arg0,"rope")!=-1)
  267. {
  268. if(has_rope[target])
  269. {
  270. console_print(id,"[AMXX] %s already has rope",name)
  271. }
  272. else
  273. {
  274. has_rope[target]=true
  275. console_print(id,"[AMXX] %s has been given rope",name)
  276. client_print(target,print_chat,"[AMXX] An admin has given you hook. Use: bind key +rope")
  277. }
  278. }
  279. }
  280. if(containi(arg0,"take")!=-1)
  281. {
  282. if(containi(arg0,"grab")!=-1)
  283. {
  284. if(!has_grab[target])
  285. {
  286. console_print(id,"[AMXX] %s doesn't have grab",name)
  287. }
  288. else
  289. {
  290. has_grab[target]=false
  291. console_print(id,"[AMXX] %s's grab has been taken away.",name)
  292. client_print(target,print_chat,"[AMXX] An admin has taken your grab away.")
  293. }
  294. }
  295. if(containi(arg0,"hook")!=-1)
  296. {
  297. if(!has_hook[target])
  298. {
  299. console_print(id,"[AMXX] %s doesn't have hook",name)
  300. }
  301. else
  302. {
  303. has_hook[target]=false
  304. console_print(id,"[AMXX] %s's hook has been taken away.",name)
  305. client_print(target,print_chat,"[AMXX] An admin has taken your hook away.")
  306. }
  307. }
  308. if(containi(arg0,"rope")!=-1)
  309. {
  310. if(!has_rope[target])
  311. {
  312. console_print(id,"[AMXX] %s doesn't have rope",name)
  313. }
  314. else
  315. {
  316. has_rope[target]=false
  317. console_print(id,"[AMXX] %s's rope has been taken away.",name)
  318. client_print(target,print_chat,"[AMXX] An admin has taken your rope away.")
  319. }
  320. }
  321. }
  322. return PLUGIN_HANDLED
  323. }
  324.  
  325.  
  326. /*****
  327. Grab
  328. *****/
  329.  
  330. public grab_toggle(id,level,cid)
  331. {
  332. if(grab[id]) grab_off(id)
  333. else grab_on(id,level,cid)
  334. return PLUGIN_HANDLED
  335. }
  336.  
  337. public grab_on(id,level,cid)
  338. {
  339. if(!has_grab[id] && !get_pcvar_num(grab_enabled_cvar) && !cmd_access(id,level,cid,1))
  340. {
  341. return PLUGIN_HANDLED
  342. }
  343. if(grab[id])
  344. {
  345. return PLUGIN_HANDLED
  346. }
  347. grab[id]=-1
  348. static target, trash
  349. target=0
  350. get_user_aiming(id,target,trash)
  351. if(target && is_valid_ent2(target) && target!=id)
  352. {
  353. if(target<=maxplayers)
  354. {
  355. if(is_user_alive(target) && !(get_user_flags(target) & ADMIN_IMMUNITY))
  356. {
  357. client_print(id,print_chat,"[AMXX] Found Target")
  358. grabem(id,target)
  359. }
  360. }
  361. else if(get_solidity(target)!=4)
  362. {
  363. client_print(id,print_chat,"[AMXX] Found Target")
  364. grabem(id,target)
  365. }
  366. }
  367. else
  368. {
  369. client_print(id,print_chat,"[AMXX] Searching for Target")
  370. set_task(0.1,"grab_on2",id)
  371. }
  372. return PLUGIN_HANDLED
  373. }
  374.  
  375. public grab_on2(id)
  376. {
  377. if(is_user_connected(id))
  378. {
  379. static target, trash
  380. target=0
  381. get_user_aiming(id,target,trash)
  382. if(target && is_valid_ent2(target) && target!=id)
  383. {
  384. if(target<=maxplayers)
  385. {
  386. if(is_user_alive(target) && !(get_user_flags(target) & ADMIN_IMMUNITY))
  387. {
  388. client_print(id,print_chat,"[AMXX] Found Target")
  389. grabem(id,target)
  390. }
  391. }
  392. else if(get_solidity(target)!=4)
  393. {
  394. client_print(id,print_chat,"[AMXX] Found Target")
  395. grabem(id,target)
  396. }
  397. }
  398. else
  399. {
  400. set_task(0.1,"grab_on2",id)
  401. }
  402. }
  403. }
  404.  
  405. public grabem(id,target)
  406. {
  407. grab[id]=target
  408. set_rendering2(target,kRenderFxGlowShell,255,0,0,kRenderTransAlpha,70)
  409. if(target<=maxplayers) set_user_gravity(target,0.0)
  410. grab_totaldis[id] = 0.0
  411. set_task(0.1,"grab_prethink",id+1000,"",0,"b")
  412. grab_prethink(id+1000)
  413. emit_sound(id,CHAN_VOICE,"weapons/xbow_fire1.wav", 1.0, ATTN_NORM, 0, PITCH_NORM)
  414. }
  415.  
  416. public grab_off(id)
  417. {
  418. if(is_user_connected(id))
  419. {
  420. if(grab[id]==-1)
  421. {
  422. client_print(id,print_chat,"[AMXX] No Target Found")
  423. grab[id]=0
  424. }
  425. else if(grab[id])
  426. {
  427. client_print(id,print_chat,"[AMXX] Target Released")
  428. set_rendering2(grab[id])
  429. if(grab[id]<=maxplayers && is_user_alive(grab[id])) set_user_gravity(grab[id],1.0)
  430. grab[id]=0
  431. }
  432. }
  433. return PLUGIN_HANDLED
  434. }
  435.  
  436. public grab_prethink(id)
  437. {
  438. id -= 1000
  439. if(!is_user_connected(id) && grab[id]>0)
  440. {
  441. set_rendering2(grab[id])
  442. if(grab[id]<=maxplayers && is_user_alive(grab[id])) set_user_gravity(grab[id],1.0)
  443. grab[id]=0
  444. }
  445. if(!grab[id] || grab[id]==-1)
  446. {
  447. remove_task(id+1000)
  448. return PLUGIN_HANDLED
  449. }
  450.  
  451. //Get Id's, target's, and Where Id is looking's origins
  452. static origin1[3]
  453. get_user_origin(id,origin1)
  454. static Float:origin2_F[3], origin2[3]
  455. get_origin(grab[id],origin2_F)
  456. origin2[0] = floatround(origin2_F[0])
  457. origin2[1] = floatround(origin2_F[1])
  458. origin2[2] = floatround(origin2_F[2])
  459. static origin3[3]
  460. get_user_origin(id,origin3,3)
  461.  
  462. //Create red beam
  463. message_begin(MSG_BROADCAST,SVC_TEMPENTITY)
  464. write_byte(1) //TE_BEAMENTPOINT
  465. write_short(id) // start entity
  466. write_coord(origin2[0])
  467. write_coord(origin2[1])
  468. write_coord(origin2[2])
  469. write_short(beamsprite)
  470. write_byte(1) // framestart
  471. write_byte(1) // framerate
  472. write_byte(1) // life in 0.1's
  473. write_byte(5) // width
  474. write_byte(0) // noise
  475. write_byte(255) // red
  476. write_byte(0) // green
  477. write_byte(0) // blue
  478. write_byte(200) // brightness
  479. write_byte(0) // speed
  480. message_end()
  481.  
  482. //Convert to floats for calculation
  483. static Float:origin1_F[3]
  484. static Float:origin3_F[3]
  485. origin1_F[0] = float(origin1[0])
  486. origin1_F[1] = float(origin1[1])
  487. origin1_F[2] = float(origin1[2])
  488. origin3_F[0] = float(origin3[0])
  489. origin3_F[1] = float(origin3[1])
  490. origin3_F[2] = float(origin3[2])
  491.  
  492. //Calculate target's new velocity
  493. static Float:distance[3]
  494.  
  495. if(!grab_totaldis[id])
  496. {
  497. distance[0] = floatabs(origin1_F[0] - origin2_F[0])
  498. distance[1] = floatabs(origin1_F[1] - origin2_F[1])
  499. distance[2] = floatabs(origin1_F[2] - origin2_F[2])
  500. grab_totaldis[id] = floatsqroot(distance[0]*distance[0] + distance[1]*distance[1] + distance[2]*distance[2])
  501. }
  502. distance[0] = origin3_F[0] - origin1_F[0]
  503. distance[1] = origin3_F[1] - origin1_F[1]
  504. distance[2] = origin3_F[2] - origin1_F[2]
  505.  
  506. static Float:grab_totaldis2
  507. grab_totaldis2 = floatsqroot(distance[0]*distance[0] + distance[1]*distance[1] + distance[2]*distance[2])
  508.  
  509. static Float:que
  510. que = grab_totaldis[id] / grab_totaldis2
  511.  
  512. static Float:origin4[3]
  513. origin4[0] = ( distance[0] * que ) + origin1_F[0]
  514. origin4[1] = ( distance[1] * que ) + origin1_F[1]
  515. origin4[2] = ( distance[2] * que ) + origin1_F[2]
  516.  
  517. static Float:velocity[3]
  518. velocity[0] = (origin4[0] - origin2_F[0]) * (get_pcvar_float(grab_speed_cvar) / 1.666667)
  519. velocity[1] = (origin4[1] - origin2_F[1]) * (get_pcvar_float(grab_speed_cvar) / 1.666667)
  520. velocity[2] = (origin4[2] - origin2_F[2]) * (get_pcvar_float(grab_speed_cvar) / 1.666667)
  521.  
  522. set_velo(grab[id],velocity)
  523.  
  524. return PLUGIN_CONTINUE
  525. }
  526.  
  527.  
  528. /*****
  529. Hook
  530. *****/
  531.  
  532. public hook_toggle(id,level,cid)
  533. {
  534. if(hook[id]) hook_off(id)
  535. else hook_on(id,level,cid)
  536. return PLUGIN_HANDLED
  537. }
  538.  
  539. public hook_on(id,level,cid)
  540. {
  541. if(!has_hook[id] && !get_pcvar_num(hook_enabled_cvar) && !cmd_access(id,level,cid,1))
  542. {
  543. return PLUGIN_HANDLED
  544. }
  545. if(hook[id])
  546. {
  547. return PLUGIN_HANDLED
  548. }
  549. set_user_gravity(id,0.0)
  550. set_task(0.1,"hook_prethink",id+10000,"",0,"b")
  551. hook[id]=true
  552. hook_to[id][0]=999999
  553. hook_prethink(id+10000)
  554. emit_sound(id,CHAN_VOICE,"weapons/xbow_hit2.wav", 1.0, ATTN_NORM, 0, PITCH_NORM)
  555. return PLUGIN_HANDLED
  556. }
  557.  
  558. public hook_off(id)
  559. {
  560. if(is_user_alive(id)) set_user_gravity(id)
  561. hook[id]=false
  562. return PLUGIN_HANDLED
  563. }
  564.  
  565. public hook_prethink(id)
  566. {
  567. id -= 10000
  568. if(!is_user_alive(id))
  569. {
  570. hook[id]=false
  571. }
  572. if(!hook[id])
  573. {
  574. remove_task(id+10000)
  575. return PLUGIN_HANDLED
  576. }
  577.  
  578. //Get Id's origin
  579. static origin1[3]
  580. get_user_origin(id,origin1)
  581.  
  582. if(hook_to[id][0]==999999)
  583. {
  584. static origin2[3]
  585. get_user_origin(id,origin2,3)
  586. hook_to[id][0]=origin2[0]
  587. hook_to[id][1]=origin2[1]
  588. hook_to[id][2]=origin2[2]
  589. }
  590.  
  591. //Create blue beam
  592. message_begin(MSG_BROADCAST,SVC_TEMPENTITY)
  593. write_byte(1) //TE_BEAMENTPOINT
  594. write_short(id) // start entity
  595. write_coord(hook_to[id][0])
  596. write_coord(hook_to[id][1])
  597. write_coord(hook_to[id][2])
  598. write_short(beamsprite)
  599. write_byte(1) // framestart
  600. write_byte(1) // framerate
  601. write_byte(2) // life in 0.1's
  602. write_byte(5) // width
  603. write_byte(0) // noise
  604. write_byte(0) // red
  605. write_byte(0) // green
  606. write_byte(255) // blue
  607. write_byte(200) // brightness
  608. write_byte(0) // speed
  609. message_end()
  610.  
  611. //Calculate Velocity
  612. static Float:velocity[3]
  613. velocity[0] = (float(hook_to[id][0]) - float(origin1[0])) * 3.0
  614. velocity[1] = (float(hook_to[id][1]) - float(origin1[1])) * 3.0
  615. velocity[2] = (float(hook_to[id][2]) - float(origin1[2])) * 3.0
  616.  
  617. static Float:y
  618. y = velocity[0]*velocity[0] + velocity[1]*velocity[1] + velocity[2]*velocity[2]
  619.  
  620. static Float:x
  621. x = (get_pcvar_float(hook_speed_cvar) * 120.0) / floatsqroot(y)
  622.  
  623. velocity[0] *= x
  624. velocity[1] *= x
  625. velocity[2] *= x
  626.  
  627. set_velo(id,velocity)
  628.  
  629. return PLUGIN_CONTINUE
  630. }
  631.  
  632.  
  633. /*****
  634. Rope
  635. *****/
  636.  
  637. public rope_toggle(id,level,cid)
  638. {
  639. if(rope[id]) rope_off(id)
  640. else rope_on(id,level,cid)
  641. return PLUGIN_HANDLED
  642. }
  643.  
  644. public rope_on(id,level,cid)
  645. {
  646. if(!has_rope[id] && !get_pcvar_num(rope_enabled_cvar) && !cmd_access(id,level,cid,1))
  647. {
  648. return PLUGIN_HANDLED
  649. }
  650. if(rope[id])
  651. {
  652. return PLUGIN_HANDLED
  653. }
  654. set_task(0.1,"rope_prethink",id+100000,"",0,"b")
  655. rope[id]=true
  656. rope_to[id][0]=999999
  657. rope_prethink(id+100000)
  658. emit_sound(id,CHAN_VOICE,"weapons/xbow_hit2.wav", 1.0, ATTN_NORM, 0, PITCH_NORM)
  659. return PLUGIN_HANDLED
  660. }
  661.  
  662. public rope_off(id)
  663. {
  664. rope[id]=false
  665. return PLUGIN_HANDLED
  666. }
  667.  
  668. public rope_prethink(id)
  669. {
  670. id -= 100000
  671. if(!is_user_alive(id))
  672. {
  673. rope[id]=false
  674. }
  675. if(!rope[id])
  676. {
  677. remove_task(id+100000)
  678. return PLUGIN_HANDLED
  679. }
  680.  
  681. //Get Id's origin
  682. static origin1[3]
  683. get_user_origin(id,origin1)
  684.  
  685. static Float:origin1_F[3]
  686. origin1_F[0] = float(origin1[0])
  687. origin1_F[1] = float(origin1[1])
  688. origin1_F[2] = float(origin1[2])
  689.  
  690. //Check to see if this is the first time prethink is being run
  691. if(rope_to[id][0]==999999)
  692. {
  693. static origin2[3]
  694. get_user_origin(id,origin2,3)
  695. rope_to[id][0]=origin2[0]
  696. rope_to[id][1]=origin2[1]
  697. rope_to[id][2]=origin2[2]
  698.  
  699. static Float:origin2_F[3]
  700. origin2_F[0] = float(origin2[0])
  701. origin2_F[1] = float(origin2[1])
  702. origin2_F[2] = float(origin2[2])
  703.  
  704. static Float:distance[3]
  705. distance[0] = floatabs(origin1_F[0] - origin2_F[0])
  706. distance[1] = floatabs(origin1_F[1] - origin2_F[1])
  707. distance[2] = floatabs(origin1_F[2] - origin2_F[2])
  708. rope_totaldis[id] = floatsqroot(distance[0]*distance[0] + distance[1]*distance[1] + distance[2]*distance[2])
  709. }
  710.  
  711. //Create green beam
  712. message_begin(MSG_BROADCAST,SVC_TEMPENTITY)
  713. write_byte(1) //TE_BEAMENTPOINT
  714. write_short(id) // start entity
  715. write_coord(rope_to[id][0])
  716. write_coord(rope_to[id][1])
  717. write_coord(rope_to[id][2])
  718. write_short(beamsprite)
  719. write_byte(1) // framestart
  720. write_byte(1) // framerate
  721. write_byte(1) // life in 0.1's
  722. write_byte(5) // width
  723. write_byte(0) // noise
  724. write_byte(0) // red
  725. write_byte(255) // green
  726. write_byte(0) // blue
  727. write_byte(200) // brightness
  728. write_byte(0) // speed
  729. message_end()
  730.  
  731. //Calculate Velocity
  732. static Float:velocity[3]
  733. get_velo(id,velocity)
  734.  
  735. static Float:velocity2[3]
  736. velocity2[0] = (rope_to[id][0] - origin1_F[0]) * 3.0
  737. velocity2[1] = (rope_to[id][1] - origin1_F[1]) * 3.0
  738.  
  739. static Float:y
  740. y = velocity2[0]*velocity2[0] + velocity2[1]*velocity2[1]
  741.  
  742. static Float:x
  743. x = (get_pcvar_float(rope_speed_cvar) * 20.0) / floatsqroot(y)
  744.  
  745. velocity[0] += velocity2[0]*x
  746. velocity[1] += velocity2[1]*x
  747.  
  748. if(rope_to[id][2] - origin1_F[2] >= rope_totaldis[id] && velocity[2]<0.0) velocity[2] *= -1
  749.  
  750. set_velo(id,velocity)
  751.  
  752. return PLUGIN_CONTINUE
  753. }
  754.  
  755. public get_origin(ent,Float:origin[3])
  756. {
  757. #if defined engine
  758. return entity_get_vector(id,EV_VEC_origin,origin)
  759. #else
  760. return pev(ent,pev_origin,origin)
  761. #endif
  762. }
  763.  
  764. public set_velo(id,Float:velocity[3])
  765. {
  766. #if defined engine
  767. return set_user_velocity(id,velocity)
  768. #else
  769. return set_pev(id,pev_velocity,velocity)
  770. #endif
  771. }
  772.  
  773. public get_velo(id,Float:velocity[3])
  774. {
  775. #if defined engine
  776. return get_user_velocity(id,velocity)
  777. #else
  778. return pev(id,pev_velocity,velocity)
  779. #endif
  780. }
  781.  
  782. public is_valid_ent2(ent)
  783. {
  784. #if defined engine
  785. return is_valid_ent(ent)
  786. #else
  787. return pev_valid(ent)
  788. #endif
  789. }
  790.  
  791. public get_solidity(ent)
  792. {
  793. #if defined engine
  794. return entity_get_int(ent,EV_INT_solid)
  795. #else
  796. return pev(ent,pev_solid)
  797. #endif
  798. }
  799.  
  800. stock set_rendering2(index, fx=kRenderFxNone, r=255, g=255, b=255, render=kRenderNormal, amount=16)
  801. {
  802. #if defined engine
  803. return set_rendering(index,fx,r,g,b,render,amount)
  804. #else
  805. set_pev(index, pev_renderfx, fx);
  806. new Float:RenderColor[3];
  807. RenderColor[0] = float(r);
  808. RenderColor[1] = float(g);
  809. RenderColor[2] = float(b);
  810. set_pev(index, pev_rendercolor, RenderColor);
  811. set_pev(index, pev_rendermode, render);
  812. set_pev(index, pev_renderamt, float(amount));
  813. return 1;
  814. #endif
  815. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement