我使用自定义NSValueTransformer在我的Core Data商店中存储颜色信息。一旦颜色数据已经存储在商店中(即,一旦应用程序已经运行并且已经退出一次),可转换数据和UIColor实例之间的转换效果很好。但是,当我第一次运行应用程序并加载这些值(从文本文件中)时,它们“卡住”为NSCFStrings。
在这行代码中,“attributes”是一个字典,其中包含NSManagedObject属性名称和值,这些属性是这些属性的预期值。在我的颜色示例中,键值对是“颜色”:“1,1,1,0.5”
[object setValue:[attributes valueForKey:attribute] forKey:attribute];
“color”的值现在将保留为此实例中的字符串,直到它通过我的NSValueTransformer进行转换,然后在应用再次运行时重新转换为UIColor。
我可以在NSValueTransformer中执行相同的转换,但这是在我编写的实用程序类中,理论上可以用于任何转换器。我还想到找到一种方法来将所有新创建的NSManagedObject实例从内存中取出,从而迫使转换完成,但这看起来像是一个黑客。
注意:这个“黑客”对我有用,让我继续,但仍然觉得难看。如果您遇到类似问题/寻找“正常工作”解决方案,请使用NSManagedObjectContext的重置方法。
有什么想法吗?
(我有预感这类似于“Why is my transformable Core Data attribute not using my custom NSValueTransformer?”但在标题之外我们的问题似乎有所不同)
这是我的NSValueTransformer
@implementation UIColorRGBValueTransformer
+ (Class)transformedValueClass
{
return [NSData class];
}
+ (BOOL)allowsReverseTransformation
{
return YES;
}
- (id)transformedValue:(id)value
{
return [value dataUsingEncoding:NSUTF8StringEncoding];
}
- (id)reverseTransformedValue:(id)value
{
NSString *colorAsString = [[[NSString alloc] initWithData:value encoding:NSUTF8StringEncoding] autorelease];
NSArray *components = [colorAsString componentsSeparatedByString:@","];
CGFloat r = [[components objectAtIndex:0] floatValue];
CGFloat g = [[components objectAtIndex:1] floatValue];
CGFloat b = [[components objectAtIndex:2] floatValue];
CGFloat a = [[components objectAtIndex:3] floatValue];
return [UIColor colorWithRed:r green:g blue:b alpha:a];
return nil;
}
@end
答案 0 :(得分:0)
您实际上并未按预期使用可转换属性。你的方法应该在理论上运作,但它是一个丑陋的kludge。
当您想要执行非标准操作时,通常只需为系统定义的类编写自定义值转换器。在绝大多数情况下,首选方法是使用默认的NSKeyedUnarchiveFromDataTransformerName。任何实现NSCoding协议的类都可以使用该值转换器。
由于UIColor确实实现了NSCoding协议,你可以将属性设置为'transformable',NSKeyedUnarchiveFromDataTransformerName
将自动填充变换器名称(至少在Xcode 3.x中填充)。使用中,Core数据将创建适当的访问器,以便您可以像设置任何其他键一样设置和获取UIColor属性:
[aMoObject setValue:aUIcolorObj forKey:@"colorAttributeName"];
作为一个好的经验法则,API将在API类的情况下为您完成大部分工作。如果你发现自己正在努力使用系统类,那么你可能错过了一些东西。