Я наблюдаю за IOS приложением, когда интерфейс представлен многими CALayers .Однажды я заметил, что CPU загружается другими процессами (на самом деле не приложением) во время обновления графики.Я начал отключать обновление частей интерфейса и перешел к тому моменту, когда обновлялся только ONE CALayer (при 50-60 Гц ), но все остальные слои (сотни) тоже отображались статически.,Таким образом, обновление только этого ОДНОГО слоя стоит 60-70% загрузки ЦП другими процессами.Когда отключено обновление только этого слоя, CPU не загружается.
Кто-нибудь может сказать, что здесь происходит ??
[CATransaction begin];
[CATransaction setValue:(id)kCFBooleanTrue forKey:kCATransactionDisableActions];
// update layer which is sublayer of self.view.layer
self.headingCircularScaleLayer.transform = CATransform3DMakeRotation(DegToRad(-newHeadingAngle_deg), 0, 0, 1);
[self.view.layer setNeedsLayout];
[CATransaction commit];
Здесь headingCircularScaleLayer - это CALayer, для содержимого которого установлено некоторое изображение
NOTE_1: (проверка загрузки процессора путем добавления нескольких слоев и их обновления)
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
}
-(void) viewDidAppear:(BOOL)animated {
[self createAndSetupLayers];
CADisplayLink *displayLink = [CADisplayLink displayLinkWithTarget:self selector:@selector(updateLayers)];
[displayLink addToRunLoop:[NSRunLoop mainRunLoop] forMode:NSDefaultRunLoopMode];
self.startTime = [[NSDate date] timeIntervalSince1970];
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
-(void) createAndSetupLayers {
NSMutableArray<CALayer*>* newLayersArray = [[NSMutableArray alloc] init];
long numOfRows = 28;
long numOfCols = 21;
long numOfLayers = numOfRows * numOfCols;
CGFloat cellWidth = self.view.bounds.size.width / numOfCols;
CGFloat cellHeight = self.view.bounds.size.height / numOfRows;
CGFloat layerWidth = cellWidth * 0.9;
CGFloat layerHeight = cellHeight * 0.9;
long currRow = 0;
long currCol = 0;
for (long i = 0; i < numOfLayers; i++)
{
currRow = i / numOfCols;
currCol = i % numOfCols;
CALayer* newLayer = [[CALayer alloc] init];
newLayer.bounds = CGRectMake(0.0, 0.0, layerWidth, layerHeight);
newLayer.anchorPoint = CGPointMake(0.5, 0.5);
newLayer.position = CGPointMake((currCol + 0.5) * cellWidth, (currRow + 0.5) * cellHeight);
newLayer.backgroundColor = [UIColor greenColor].CGColor;
//newLayer.opacity = 0.5;
//NSDictionary *newActions = @{ @"transform": [NSNull null] };
//newLayer.actions = newActions;
newLayer.actions = @{ @"contents": [NSNull null], @"position": [NSNull null],
@"frame": [NSNull null], @"opacity": [NSNull null],
@"bounds": [NSNull null], @"affineTransform": [NSNull null],
@"sublayerTransform": [NSNull null], @"transform": [NSNull null],
@"zPosition": [NSNull null], @"anchorPoint": [NSNull null],
@"cornerRadius": [NSNull null], @"sublayers": [NSNull null],
@"onLayout": [NSNull null], };
CALayer* newColorLayer = [[CALayer alloc] init];
newColorLayer.bounds = CGRectMake(0.0, 0.0, layerWidth, layerHeight);
newColorLayer.anchorPoint = CGPointMake(0.5, 0.5);
newColorLayer.position = CGPointMake(0.5 * layerWidth, 0.5 * layerHeight);
newColorLayer.opacity = 0.5;
newColorLayer.opaque = YES;
newColorLayer.backgroundColor = [UIColor redColor].CGColor;
//[newLayer addSublayer:newColorLayer];
[self.view.layer addSublayer:newLayer];
[newLayersArray addObject:newLayer];
}
self.layersArray = newLayersArray;
}
-(void) updateLayers {
double currTime = [[NSDate date] timeIntervalSince1970] - self.startTime;
double currLayerAngle = 0.5 * currTime;
NSLog(@"%.2f %.2f", currTime, currLayerAngle);
//[CATransaction begin];
//[CATransaction setValue:(id)kCFBooleanTrue forKey:kCATransactionDisableActions];
//[CATransaction setAnimationDuration:0.0];
for (CALayer *currLayer in self.layersArray)
{
currLayer.transform = CATransform3DMakeRotation(currLayerAngle, 0, 0, 1);
}
//[CATransaction commit];
}
@end