mirror of
https://github.com/zydeco/minivmac4ios.git
synced 2024-11-24 16:31:04 +00:00
prefer pixel-perfect scaling when filter is set to nearest
This commit is contained in:
parent
65d377884b
commit
da3f639ef2
@ -29,7 +29,7 @@ static ScreenView *sharedScreenView = nil;
|
||||
[self updateVideoLayer];
|
||||
[self.layer addSublayer:videoLayer];
|
||||
[[AppDelegate sharedInstance] addObserver:self forKeyPath:@"sharedEmulator" options:NSKeyValueObservingOptionNew context:NULL];
|
||||
[[NSUserDefaults standardUserDefaults] addObserver:self forKeyPath:@"screenFilter" options:NSKeyValueObservingOptionNew context:NULL];
|
||||
[[NSUserDefaults standardUserDefaults] addObserver:self forKeyPath:@"screenFilter" options:NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOld context:NULL];
|
||||
}
|
||||
|
||||
+ (instancetype)sharedScreenView {
|
||||
@ -57,17 +57,25 @@ static ScreenView *sharedScreenView = nil;
|
||||
- (void)layoutSubviews {
|
||||
[super layoutSubviews];
|
||||
CGRect viewBounds = self.bounds;
|
||||
CGFloat screenScale = MAX(screenSize.width / viewBounds.size.width, screenSize.height / viewBounds.size.height);
|
||||
if (screenScale > 0.9 && screenScale <= 1.0) {
|
||||
CGFloat screenScale = MIN(viewBounds.size.width / screenSize.width, viewBounds.size.height / screenSize.height);
|
||||
NSString *screenFilter = [[NSUserDefaults standardUserDefaults] stringForKey:@"screenFilter"];
|
||||
if ([screenFilter isEqualToString:kCAFilterNearest] && screenScale > 1.0) {
|
||||
screenScale = floor(screenScale);
|
||||
} else if (screenScale > 1.0 && screenScale <= 1.1) {
|
||||
screenScale = 1.0;
|
||||
}
|
||||
screenBounds = CGRectMake(0, 0, screenSize.width / screenScale, screenSize.height / screenScale);
|
||||
screenBounds = CGRectMake(0, 0, screenSize.width * screenScale, screenSize.height * screenScale);
|
||||
screenBounds.origin.x = (viewBounds.size.width - screenBounds.size.width)/2;
|
||||
screenBounds = CGRectIntegral(screenBounds);
|
||||
|
||||
if ([UIDevice currentDevice].userInterfaceIdiom == UIUserInterfaceIdiomPad && (viewBounds.size.height - screenBounds.size.height) >= 30.0) {
|
||||
// move under multitasking indicator on iPad
|
||||
screenBounds.origin.y += 30;
|
||||
}
|
||||
videoLayer.frame = screenBounds;
|
||||
screenBounds.origin.y = self.frame.origin.y;
|
||||
screenBounds.origin.y += self.frame.origin.y;
|
||||
BOOL scaleIsIntegral = (floor(screenScale) == screenScale);
|
||||
NSString *screenFilter = scaleIsIntegral ? kCAFilterNearest : [[NSUserDefaults standardUserDefaults] stringForKey:@"screenFilter"];
|
||||
if (scaleIsIntegral) screenFilter = kCAFilterNearest;
|
||||
videoLayer.magnificationFilter = screenFilter;
|
||||
videoLayer.minificationFilter = screenFilter;
|
||||
}
|
||||
@ -75,13 +83,19 @@ static ScreenView *sharedScreenView = nil;
|
||||
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSKeyValueChangeKey,id> *)change context:(void *)context {
|
||||
if ([object isEqual:[NSUserDefaults standardUserDefaults]]) {
|
||||
if ([keyPath isEqualToString:@"screenFilter"]) {
|
||||
NSString *oldValue = change[NSKeyValueChangeOldKey];
|
||||
NSString *value = change[NSKeyValueChangeNewKey];
|
||||
videoLayer.magnificationFilter = value;
|
||||
videoLayer.minificationFilter = value;
|
||||
if ([value isEqualToString:kCAFilterNearest] || [oldValue isEqualToString:kCAFilterNearest]) {
|
||||
[self setNeedsLayout];
|
||||
[self layoutIfNeeded];
|
||||
}
|
||||
}
|
||||
} else if (object == [AppDelegate sharedInstance] && [keyPath isEqualToString:@"sharedEmulator"]) {
|
||||
[self updateVideoLayer];
|
||||
[self layoutSubviews];
|
||||
[self setNeedsLayout];
|
||||
[self layoutIfNeeded];
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user