Difference between revisions of "Updating extensions for iOS 13"

From iPhone Development Wiki
Jump to: navigation, search
(What has changed in iOS 13? (Classes, frameworks, etc.): mainScene info)
(Bug is not new, has been on https://iphonedevwiki.net/index.php?title=Cydia_Substrate_Pitfalls&diff=743&oldid=742 since 2010)
 
Line 66: Line 66:
  
 
UIImage *iconImage = [icon generateIconImageWithInfo:imageInfo];
 
UIImage *iconImage = [icon generateIconImageWithInfo:imageInfo];
</source>
 
 
== UIDevice issue ==
 
 
<code>[UIDevice currentDevice]</code> may causes some process crashes when it called in %ctor
 
 
To reproduce that, add this to your tweak, then change your wallpaper via Settings. The device gets stuck and reboot.
 
 
<source lang="objc">
 
%ctor {
 
  NSLog(@"[UIDevice currrentDevice] is %@", [UIDevice currentDevice]);
 
  %init;
 
}
 
 
</source>
 
</source>

Latest revision as of 00:39, 21 June 2020

Let's collect knowledge like we did with iOS 12, iOS 11, iOS 10, iOS 9, iOS 8 and iOS 7 – paste in your notes and share what you've learned, and somebody else will organize it later. :) If you want to ask questions and share tips over chat with other developers, see How to use IRC for how to connect to #theos and #iphonedev.

Hey developer, you can add your knowledge here! Yes, you! Make an account and edit this page!

If you want to see what's been recently updated on this page, you can use the wiki's history feature to compare the revisions (to look at the diff) since the last time you visited this page.

What has changed in iOS 13? (Classes, frameworks, etc.)

SBApplication -(FBScene*)mainScene removed

-[SBApplication mainScene] was removed in iOS 13. It can be accessed from a SBApplication by replacing [myApp mainScene] with the following:

[[FBSceneManager sharedInstance] sceneWithIdentifier:[myApp _baseSceneIdentifier]]

myApp being the name of your SBApplication instance.

SBRootIconListView

This class was removed entirely with iOS 13. Root Icon Lists are now instances of SBIconListView.

Home Screen Layout

SBIconListFlowLayout

Layout handling in iOS 13 now uses SBIconListFlowLayouts. These are provided by an instance of SBHDefaultIconListLayoutProvider.

This alone handles row/column count. It also contains a SBIconListGridLayoutConfiguration, which controls the spacing and location of icons.

SBIconListGridLayoutConfiguration

This class contains several properties that can be modified to alter the layout.

Selectors of interest include portraitLayoutInsets and landscapeLayoutInsets. These return an instance of UIEdgeInsets that can be used to manipulate layout.

Generating an apps icon image

Previously an icon image could be generated from an icon object like so

SBIcon *icon = someIcon;
UIImage *iconImage = [icon generateIconImage:2];

In iOS 13 this method was changed to -generateIconImageWithInfo:(struct SBIconImageInfo)info

struct SBIconImageInfo {
    CGSize size;
    CGFloat scale;
    CGFloat continuousCornerRadius;
};
SBIconController *iconController = [NSClassFromString(@"SBIconController") sharedInstance];
SBIcon *icon = [iconController.model expectedIconForDisplayIdentifier:@"com.apple.Music"];

CGSize imageSize = CGSizeMake(60, 60);

struct SBIconImageInfo imageInfo;
imageInfo.size  = imageSize;
imageInfo.scale = [UIScreen mainScreen].scale;
imageInfo.continuousCornerRadius = 12;

UIImage *iconImage = [icon generateIconImageWithInfo:imageInfo];