販売プロモーション時のアニメーション挙動修正

This commit is contained in:
kimura 2021-10-22 10:09:37 +09:00
parent 82bb891385
commit e3bb5c1c67
3 changed files with 62 additions and 21 deletions

View File

@ -98,10 +98,11 @@ public class BrotherPinkView : SingletonMonoBehaviour<BrotherPinkView>
target.localPosition = pinkTransform.localPosition;
target.localRotation = pinkTransform.localRotation;
}).AddTo(animator);
if (!isManyCustomer)
if (isManyCustomer || isPromotion)
{
SetPinkMove();
return;
}
SetPinkMove();
}
private void SetPinkMove()
@ -158,24 +159,28 @@ public class BrotherPinkView : SingletonMonoBehaviour<BrotherPinkView>
public void StopPromotion()
{
if (animator == null)
if (animator != null)
{
isPromotion = false;
ResetMove();
return;
}
var length = animator.GetCurrentAnimatorStateInfo(0).length;
var time = animator.GetCurrentAnimatorStateInfo(0).normalizedTime;
var stateInfo = animator.GetCurrentAnimatorStateInfo(0);
if (stateInfo.IsName("Brother_pink_promotion"))
{
var length = stateInfo.length;
var time = stateInfo.normalizedTime;
this.CallWaitForSeconds((1 - time % 1) * length - .3f, () =>
{
isPromotion = false;
ResetMove();
isPromotion = false;
});
return;
}
}
ResetMove();
isPromotion = false;
}
public void SetWalk()
{
if (isLocked)
if (isLocked || isPromotion)
{
return;
}

View File

@ -39,6 +39,8 @@ public class Market : SingletonMonoBehaviour<Market>
private readonly ReactiveCollection<CustomerController> waitCustomerList = new ReactiveCollection<CustomerController>();
private readonly Subject<Unit> orderSubject = new Subject<Unit>();
public readonly BoolReactiveProperty IsPause = new BoolReactiveProperty(false);
public IReadOnlyReactiveProperty<bool> IsPromotion => isPromotion;
private readonly BoolReactiveProperty isPromotion = new BoolReactiveProperty();
public Subject<int> SellObservable => sellObservable;
private readonly Subject<int> sellObservable = new Subject<int>();
@ -59,6 +61,7 @@ public class Market : SingletonMonoBehaviour<Market>
requestSubject.AddTo(this);
orderSubject.AddTo(this);
IsPause.AddTo(this);
isPromotion.AddTo(this);
var gameData = GameDataManager.GameData;
@ -99,7 +102,7 @@ public class Market : SingletonMonoBehaviour<Market>
Debug.Log($"aa order:{count} Request {Time.time} {customer.GetHashCode()}");
if (count >= maxOrder)
{
shopState.Value = ShopState.Busy;
// shopState.Value = ShopState.Busy;
return;
}
waitCustomerList.Remove(customer);
@ -149,8 +152,16 @@ public class Market : SingletonMonoBehaviour<Market>
orders.AddRange(tmpOrders);
// コーンの味吹き出しを設定
try
{
controller.SetWantFlavor(displayFlavors[tmpOrders.RandomChoose()]);
}
catch (Exception e)
{
Debug.LogError($"d:{displayFlavors.Count}, {string.Join("", tmpOrders)}");
throw;
}
}
foreach (var customerController in dontBuyCustomerList)
{
customers.Remove(customerController);
@ -513,8 +524,12 @@ public class Market : SingletonMonoBehaviour<Market>
public void AdClickAction()
{
BrotherPinkView.Instance.StartPromotion();
customerFlow.StartAdWalker(() => BrotherPinkView.Instance.StopPromotion());
isPromotion.Value = true;
customerFlow.StartAdWalker(() =>
{
isPromotion.Value = false;
BrotherPinkView.Instance.StopPromotion();
});
}
private void CheckAndFixStock()

View File

@ -28,20 +28,20 @@ public class MarketManager : MonoBehaviour
private void Start()
{
resetRefreshTimer.AddTo(this);
market = Market.Instance;
SoundManager.Instance.PlayBGM("bgm_marketing");
var gameData = GameDataManager.GameData;
CoinManager.Instance.ChangeCoin(gameData.Coin);
HeartMeter.Instance.Initialize(gameData.ViewedShopLevel, gameData.Heart);
GameDataObserver.Instance.ShopLevelUpdate
.Where(x => x)
.Where(x => x && !market.IsPromotion.Value)
.Subscribe(x =>
{
LocalCacheManager.Save(ShopLevelUp.DataTag, gameData.ViewedShopLevel + 1);
TransitionManager.Instance.LoadSceneAdditive(GameScenes.StoreLevel);
}).AddTo(this);
market = Market.Instance;
productDataList = SpreadsheetDataManager.Instance.GetBaseDataList<ProductData>(Const.ProductDataSheet);
stockView.SetStock(gameData.StorageTanks);
var startStocks = market.ShuffledOrder.Select(x => (x, market.DisplayFlavors[x])).ToList();
@ -83,6 +83,19 @@ public class MarketManager : MonoBehaviour
var remaining = (int) DateTime.FromBinary(gameData.increaseCustomerTime).Subtract(DateTime.UtcNow).TotalSeconds;
resetRefreshTimer.OnNext(remaining);
market.IsPromotion.Subscribe(active =>
{
if (active)
{
SoundManager.Instance.PlayBGM("bgm_publicity");
BrotherPinkView.Instance.StartPromotion();
}
else
{
SoundManager.Instance.PlayBGM("bgm_marketing");
}
}).AddTo(this);
// Customerの各アニメーション設定
foreach (var controller in market.CustomerControllerList)
@ -126,9 +139,17 @@ public class MarketManager : MonoBehaviour
{
// 補充したフレーバーのスキンを設定
foreach (var order in x.refillList)
{
try
{
cartView.Refill(order, market.DisplayFlavors[order]);
}
catch (Exception e)
{
Debug.LogError($"order:{order}, displayFlavors:{market.DisplayFlavors.Count}");
throw;
}
}
}
}).AddTo(this);