本文整理汇总了C#中System.Item.InvalidateCachedData方法的典型用法代码示例。如果您正苦于以下问题:C# Item.InvalidateCachedData方法的具体用法?C# Item.InvalidateCachedData怎么用?C# Item.InvalidateCachedData使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Item
的用法示例。
在下文中一共展示了Item.InvalidateCachedData方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: PropertyValueIsContinuous
/// <summary>
/// Determine whether the property in question is continuous or follows a "step" progression (at which point change points
/// must be determined). The simplest way to do this is check whether adding or subtracting 0.01 from the stat produces a
/// different value in both the addition and subtraction case. If it does, then the property is continuous (at least to
/// the resolution of the given resolution).
/// </summary>
/// <param name="character">The character whose property is being evaluated for continuity.</param>
/// <param name="baseOffset">Base offset of the property.</param>
/// <param name="basePoints">The base number of points that the character has.</param>
/// <param name="property">The property to evaluate for continuity.</param>
/// <param name="tagItem">A "tag" item to reduce memory allocation.</param>
/// <param name="resolution">The resolution at which continuity is being checked.</param>
/// <returns>Whether the property was deemed continuous.</returns>
private static bool PropertyValueIsContinuous(Character character, float baseOffset, float basePoints, PropertyInfo property, Item tagItem, float resolution)
{
bool continuous;
property.SetValue(tagItem.Stats, baseOffset + resolution, null);
tagItem.InvalidateCachedData();
continuous = basePoints != Calculations.Instance.GetCharacterCalculations(character, tagItem, false, false, false).OverallPoints;
// if continuity was detected in the first alteration, then test the second direction (to guard against cases
// where we just happen to be on the threshold)
if (continuous)
{
property.SetValue(tagItem.Stats, baseOffset - resolution, null);
tagItem.InvalidateCachedData();
// Since we've already determined that the first alteration was continuous, whether this one is
// determines whether both are continuous.
continuous = basePoints != Calculations.Instance.GetCharacterCalculations(character, tagItem, false, false, false).OverallPoints;
}
return continuous;
}
示例2: GetStatValueLowerChangePoint
private static float GetStatValueLowerChangePoint(Character character, float basePoints, PropertyInfo property, Item tagItem, float lowerBound, float upperBound, float resolution)
{
// Exit condition: If we've reached a change point at the smallest desired
// resolution, return the "no change" value.
if ((upperBound - lowerBound) <= resolution)
{
return upperBound;
}
// Recusive condition: We still need to reduce the difference between the
// upper and lower bounds of the range we are searching.
else
{
// Set the stat of the item to the mid point of the range to test which
// half contains the change point.
float midPoint = (upperBound + lowerBound) / 2f;
property.SetValue(tagItem.Stats, midPoint, null);
tagItem.InvalidateCachedData();
// If the midpoint leaves the OverallPoints unchanged, the change point
// is in the lower half of the given range.
float newOverall = Calculations.Instance.GetCharacterCalculations(character, tagItem, false, false, false).OverallPoints;
if (basePoints == newOverall)
{
return GetStatValueLowerChangePoint(character, basePoints, property, tagItem, lowerBound, midPoint, resolution);
}
// Otherwise, the change point is in the upper half of the given range.
else
{
return GetStatValueLowerChangePoint(character, basePoints, property, tagItem, midPoint, upperBound, resolution);
}
}
}
示例3: GetRelativeStatValue
/// <summary>
/// Get the relative stat value for the given property (of a Stats object) of the given Character.
/// See http://www.wowhead.com/?help=stat-weighting for more info of stat values.
/// Note that these values are volatile and should be updated whenever any aspect of the
/// character is changed.
/// </summary>
/// <param name="character">The character for which to calculate the relative stat values.</param>
/// <param name="property">The property of a Stats object for which to get the relative stat value.</param>
/// <param name="item">Offset from character at which to compute the relative stat value.</param>
/// <param name="scale">Value of how much of the property we want to evaluate.</param>
/// <returns>The comparitive calculations of the relative stat value of the given Property (of a
/// Stats object) for the given Character.</returns>
public static ComparisonCalculationBase GetRelativeStatValue(Character character, PropertyInfo property, Item item, float scale)
{
const float resolution = 0.005f; // the minimum resolution of change for the purpose of testing continuity and determining step locations
ComparisonCalculationBase ccb = null;
float minRange = CommonStat.GetCommonStatMinimumRange(property);
if (minRange >= 0)
{
// Get change bounds
CharacterCalculationsBase charCalcsBase = Calculations.GetCharacterCalculations(character, item, false, false, false);
float basePoints = charCalcsBase.OverallPoints;
float baseOffset = (float)property.GetValue(item.Stats, null);
float upperChangePoint = baseOffset + 1.0f;
float lowerChangePoint = baseOffset + 0.0f;
if (!PropertyValueIsContinuous(character, baseOffset, basePoints, property, item, resolution))
{
upperChangePoint = GetStatValueUpperChangePoint(character, basePoints, property, item, baseOffset + minRange + resolution, baseOffset + minRange + 10.0f, resolution);
lowerChangePoint = GetStatValueLowerChangePoint(character, basePoints, property, item, baseOffset - minRange - 10.0f, baseOffset - minRange, resolution);
}
float changePointDifference = upperChangePoint - lowerChangePoint;
// Get new overall points with the [upperChangePoint] improvement
property.SetValue(item.Stats, upperChangePoint, null);
item.InvalidateCachedData();
CharacterCalculationsBase charCalcsUpper = Calculations.Instance.GetCharacterCalculations(character, item, false, false, false);
// Get new overall points with the [lowerChangePoint] improvement
property.SetValue(item.Stats, lowerChangePoint, null);
item.InvalidateCachedData();
CharacterCalculationsBase charCalcsLower = Calculations.Instance.GetCharacterCalculations(character, item, false, false, false);
// Create new CCB, populate, and return it.
ccb = Calculations.CreateNewComparisonCalculation();
ccb.Name = Extensions.DisplayName(property);
// Populate SubPoints and OverallPoints
ccb.SubPoints = new float[charCalcsUpper.SubPoints.Length];
for (int i = 0; i < charCalcsUpper.SubPoints.Length; i++)
{
ccb.SubPoints[i] = scale * (charCalcsUpper.SubPoints[i] - charCalcsLower.SubPoints[i]) / changePointDifference;
ccb.OverallPoints += ccb.SubPoints[i];
}
ccb.Description = string.Format("If you had {0} more{1}", scale, ccb.Name);
}
return ccb;
}