123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192 |
- using System.Collections;
- using System.Collections.Generic;
- using UnityEngine;
- using System;
- using SC.InputSystem;
- using DG.Tweening;
- public class Bowman : PointerDelegate
- {
- [SerializeField]
- private Transform mTarget;
- [SerializeField]
- private Transform receivePoint;
- [SerializeField]
- private Transform endPoint;
- [SerializeField]
- private BloodManager.BloodItemType[] fliterTypes;
- [SerializeField]
- private BloodManager.BloodItemType[] recycleTypes;
- void Start () {
- }
- private void OnDestroy()
- {
- }
-
- void Update () {
- CheckRay();
- }
- Ray ray;
- RaycastHit hit;
- GameObject obj;
- private void CheckRay()
- {
- if(Camera.main == null)
- {
- return;
- }
- if (Input.GetMouseButtonDown(0))
- {
- ray = Camera.main.ScreenPointToRay(Input.mousePosition);
- if (Physics.Raycast(ray, out hit, float.MaxValue,1 << 0))
- {
- if (hit.rigidbody != null)
- {
- obj = hit.rigidbody.gameObject;
- CheckItem();
- }
- }
- }
- }
- private void CheckItem()
- {
- BloodItem item = obj.GetComponentInParent<BloodItem>();
- if(item != null)
- {
- if(Array.IndexOf(fliterTypes, item.MType) == -1 && false)
- {
-
- }
- else
- {
- if (item.StopMove())
- {
- ChangeItemForward(item);
- }
- }
- }
- }
-
- private void ChangeItemForward(BloodItem item)
- {
- item.transform.LookAt(mTarget);
- item.transform.DOLocalMove(mTarget.transform.position, 1.0f).SetEase(Ease.Linear).OnComplete(Test).SetAutoKill(true);
- return;
-
- Hashtable args = new Hashtable();
- args.Add("position", mTarget.transform.position);
- args.Add("time", 1.0f);
-
- args.Add("easeType", iTween.EaseType.linear);
- args.Add("oncomplete", "Arrived");
- args.Add("oncompleteparams", item);
- args.Add("oncompletetarget", gameObject);
- iTween.MoveTo(item.gameObject, args);
- }
- private void Test()
- {
- Debug.Log("到达了指定地方");
- }
-
- private void Arrived(BloodItem item)
- {
- Debug.Log("到达了指定地方" + Vector3.Distance(item.transform.position, mTarget.transform.position));
-
-
- iTween.Stop(item.gameObject);
- if (Array.IndexOf(recycleTypes, item.MType) != -1 && CheckNeedReceived(item.MType))
- {
- Debug.Log("这是可以回收的");
-
- iTween.MoveTo(item.gameObject, iTween.Hash("position", receivePoint, "easeType", iTween.EaseType.linear, "loopType", iTween.LoopType.none, "delay", 1));
- }
- else
- {
- Debug.Log("这是废物");
- iTween.MoveTo(item.gameObject, iTween.Hash("position", endPoint, "easeType", iTween.EaseType.linear, "loopType", iTween.LoopType.none, "delay", 1));
- }
- }
- private bool CheckNeedReceived(BloodManager.BloodItemType cType)
- {
- return false;
- var randomValue = UnityEngine.Random.Range(0,100);
- var max_value = 0 ;
- switch(cType)
- {
- case BloodManager.BloodItemType.Water:
- max_value = 80;
- break;
- case BloodManager.BloodItemType.MineralSalt:
- max_value = 50;
- break;
- case BloodManager.BloodItemType.Protein:
- max_value = 100;
- break;
- case BloodManager.BloodItemType.Urea:
- max_value = 0;
- break;
- }
- if(randomValue < max_value)
- {
- return true;
- }
- return false;
- }
-
- public bool IsGod(BloodItem item)
- {
- if (Array.IndexOf(fliterTypes, item.MType) != -1)
- {
- return true;
- }
- return false;
- }
-
- public bool IsRecyle(BloodItem item)
- {
- if (Array.IndexOf(recycleTypes, item.MType) != -1)
- {
- return true;
- }
- return false;
- }
- protected override void partAnyKeyDownDelegate(InputKeyCode keyCode, InputDevicePartBase part)
- {
- if (!GamePlayerData.Instance.room_data.IsReconnectOwner())
- {
-
- }
- CheckRayItem();
- }
- private void CheckRayItem()
- {
- ray = new Ray( API_InputSystem.Position, API_InputSystem.Normal);
- if (Physics.Raycast(ray, out hit, float.MaxValue, 1 << 0))
- {
- if (hit.rigidbody != null)
- {
- obj = hit.rigidbody.gameObject;
- CheckItem();
- }
- }
- }
- }
|