/FWFramework

iOS开发框架,方便iOS开发,兼容OC和Swift。

Primary LanguageObjective-CMIT LicenseMIT

FWFramework

Pod Version Pod Platform Pod License Carthage compatible

Tutorial

iOS development framework, convenient for iOS development, compatible with OC and Swift.

All Swizzles in this framework will not take effect by default and will not affect existing projects. They need to be manually opened or invoked to take effect. This library has been used in formal projects, and will continue to be maintained and expanded in the future. Everyone is welcome to use and provide valuable comments to grow together.

Installation

It is recommended to use CocoaPods to install and automatically manage dependencies. For manual import, please refer to Example project configuration.

CocoaPods

This framework supports CocoaPods, Podfile example:

platform :ios, '9.0'
use_frameworks!

target 'Example' do
  # Import the default subspecs
  pod 'FWFramework'
  
  # Import the specified subspecs, see the podspec file for the list of subspecs
  # pod 'FWFramework', :subspecs => ['FWFramework', 'Component/SDWebImage']
end

A brief description of the subspecs:

Framework: framework layer, core architecture, has nothing to do with the application, the bottom layer depends on
Application: application layer, AOP solution, no need to inherit, components can be replaced
Component: component layer, optional import, common functions, convenient for development

Carthage

This framework supports Carthage, Cartfile example:

github "lszzy/FWFramework"

Execute carthage update and copy FWFramework.framework to the project.

Changelog

As this framework is constantly upgrading, optimizing and expanding new functions, the Api of each version may be slightly changed. If a compilation error is reported when the new version is upgraded, the solution is as follows:

1. Just change to specify the pod version number to import, the recommended way, does not affect the project progress, upgrade to the new version only when you have time, example: pod'FWFramework', '1.0.0'
2. Upgrade to the new version, please pay attention to the version update log. Obsolete Api will be migrated to the Component/Deprecated submodule as appropriate, and will be deleted in subsequent versions

Version 1.4.1:

* UIScrollView supports fwOverlayView view
* UIScrollView supports displaying an empty interface and modifying the FWEmptyViewDelegate method
* Added new empty interface gradient animation configuration, which is enabled by default

Version 1.4.0:

* Refactor the implementation of FWEmptyPlugin to support scroll view and default text
* Refactored FWToastPlugin to support default text
* FWViewController added renderState state rendering method
* FWNavigationBarAppearance supports theme colors and theme pictures

Version 1.3.6:

* Add a method to get the life cycle status of ViewController
* UINavigationBar and UITabBar support quick setting of theme background images

Version 1.3.5:

* Optimize FWTabBarController, the performance is consistent with UITabBarController

Version 1.3.4:

* Refactor FWWebViewDelegate method

Version 1.3.3:

* Refactor the implementation of FWWebViewController and extract FWWebView
* FWRouter, FWMediator support preset methods

Version 1.3.2:

* FWTabBarController supports loading network pictures
* Optimize the animation effect of FWDrawerView

Version 1.3.1:

* FWPagingView supports pull-down refresh of sub-pages when hovering

Version 1.3.0:

* Refactored FWImagePlugin plug-in, refactored FWWebImage, and added option configuration
* Added FWOAuth2Manager network authorization class
* Optimize FWEncode to handle URL encoding

Version 1.2.1:

* Refactor the FWRouter routing class
* Refactor FWLoader to automatically load classes
* Refactored FWPluginManager plugin management class

Version 1.2.0:

* Optimize the controller fwTopBarHeight algorithm
* Added FWQrcodeScanView configuration parameters
* Added FWSignatureView view component

Version 1.1.1:

* Optimize FWRouter empty string handling
* Refactor the design and implementation of FWView, support Delegate and Block
* Added FWNetworkUtils.isRequestError error judgment method

Version 1.1.0:

* Optimize framework OC attribute declaration, Swift call is more friendly
* FWAutoloader was renamed to FWLoader
* Code optimization, Example project optimization

Version 1.0.6:

* Add RSA encryption and decryption, signature verification algorithm
* FWPasscodeView added configuration parameters

Version 1.0.5:

* FWAlertController supports custom textField keyboard management

Version 1.0.4:

* Added FWPasscodeView component

Version 1.0.3:

* FWTheme and FWImage classes support bundle loading
* FWPhotoBrowser supports UIImage parameters
* Example project reconstruction, modularization and continuous integration example

Version 1.0.2:

* Add FWAutoloader automatic loading class
* Optimize FWWebViewController button handling

Version 1.0.1:

* Optimize screen adaptation constants, see FWAdaptive for details

Version 1.0.0:

* After two years of hard work, version 1.0.0 was released

Vendor

This framework uses a lot of third-party libraries. Thanks to the authors of all third-party libraries. I will not list them all here. For details, please refer to the relevant links of the source file.

In the introduction of third-party libraries, in order to be compatible with existing project pod dependencies, as well as to customize changes and bug fixes of third-party libraries, and to facilitate subsequent maintenance, this framework uniformly modified the FW class prefix and fw method prefix. If there is any inconvenience during use, Please understand.
If you are the author of a third-party open source library, if this library violates your rights, please let me know, and I will immediately remove the use of the third-party open source library. 

Support

wuyong.site