/MMPlaceHolder

A drop in solution to show UIView's size. Only one line code to use it.

Primary LanguageObjective-CMIT LicenseMIT

MMPlaceHolder

Total views Views in the last 24 hours

A drop in solution to set a placeholder or show UIView's size

中文介绍

you can use it for frame debug demo

or you can use it for size debug show

Installation

The preferred way of installation is via CocoaPods. Just add

pod 'MMPlaceHolder'

and run pod install. It will install the most recent version of MMPlaceHolder.

If you would like to use the latest code of MMPlaceHolder use:

pod 'MMPlaceHolder', :head

Usage

simply, you only need one line code.

[yourView showPlaceHolder];

or you can customize youself.

@interface  UIView(MMPlaceHolder)

- (void)showPlaceHolder;
- (void)showPlaceHolderWithAllSubviews;
- (void)showPlaceHolderWithAllSubviews:(NSInteger)maxDepth;
- (void)showPlaceHolderWithLineColor:(UIColor*)lineColor;
- (void)showPlaceHolderWithLineColor:(UIColor*)lineColor backColor:(UIColor*)backColor;
- (void)showPlaceHolderWithLineColor:(UIColor*)lineColor backColor:(UIColor*)backColor arrowSize:(CGFloat)arrowSize;
- (void)showPlaceHolderWithLineColor:(UIColor*)lineColor backColor:(UIColor*)backColor arrowSize:(CGFloat)arrowSize lineWidth:(CGFloat)lineWidth;
- (void)showPlaceHolderWithLineColor:(UIColor*)lineColor backColor:(UIColor*)backColor arrowSize:(CGFloat)arrowSize lineWidth:(CGFloat)lineWidth frameWidth:(CGFloat)frameWidth frameColor:(UIColor*)frameColor;

- (void)hidePlaceHolder;
- (void)hidePlaceHolderWithAllSubviews;
- (void)removePlaceHolder;
- (void)removePlaceHolderWithAllSubviews;
- (MMPlaceHolder *)getPlaceHolder;

@end

and you can use the global configuration

@interface MMPlaceHolderConfig : NSObject

+ (MMPlaceHolderConfig*) defaultConfig;

@property (nonatomic, strong) UIColor *backColor;
@property (nonatomic, assign) CGFloat arrowSize;
@property (nonatomic, strong) UIColor *lineColor;
@property (nonatomic, assign) CGFloat lineWidth;
@property (nonatomic, strong) UIColor *frameColor;
@property (nonatomic, assign) CGFloat frameWidth;

@property (nonatomic, assign) BOOL showArrow;
@property (nonatomic, assign) BOOL showText;


@property (nonatomic, assign) BOOL visible;
@property (nonatomic, assign) BOOL autoDisplay;
@property (nonatomic, strong) NSArray *visibleMemberOfClasses;
@property (nonatomic, strong) NSArray *visibleKindOfClasses;

@end

Changelog

v1.8 now you can hide the system view and keep the interface clean & tidy

    
	@property (nonatomic, assign) BOOL autoDisplaySystemView;

v1.7 now you can display the specific class while in Autodisplay mode(thx pull request from @mrdaios)

    
    @property (nonatomic, strong) NSArray *visibleMemberOfClasses;
    @property (nonatomic, strong) NSArray *visibleKindOfClasses;

    [MMPlaceHolderConfig defaultConfig].visibleMemberOfClasses = @[UIImageView.class];
    [MMPlaceHolderConfig defaultConfig].visibleKindOfClasses   = @[UIButton.class];

v1.6 now you can control the visibility of frame & arrow & text by

	@property (nonatomic, strong) UIColor *frameColor;
	@property (nonatomic, assign) CGFloat frameWidth;

	[MMPlaceHolderConfig defaultConfig].showArrow = YES;
	[MMPlaceHolderConfig defaultConfig].showText = YES;

and modified the function hidePlaceHolder & add new function removePlaceHolder

	- (void)removePlaceHolder;
	- (void)removePlaceHolderWithAllSubviews;

most important thing is you can automatic display the placeholder with one line code by

    [MMPlaceHolderConfig defaultConfig].autoDisplay = YES;

v1.5 fix hidePlaceHolder bug when subviews shows placeholder

v1.4 add a demo project & now you can config the global visability by

    [MMPlaceHolderConfig defaultConfig].visible = NO;

v1.3 now you can add placeholders recursively by

    - (void)showPlaceHolderWithAllSubviews;
    - (void)showPlaceHolderWithAllSubviews:(NSInteger)maxDepth;
    - (void)hidePlaceHolderWithAllSubviews;

v1.2 now you can change default configuration by [MMPlaceHolderConfig defaultConfig]

    [MMPlaceHolderConfig defaultConfig].lineColor = [UIColor whiteColor];
    [MMPlaceHolderConfig defaultConfig].backColor = [UIColor clearColor];
    [MMPlaceHolderConfig defaultConfig].arrowSize = 3;
    [MMPlaceHolderConfig defaultConfig].lineWidth = 1;

v1.1 now you can get or remove MMPlaceHolder by

    - (void)hidePlaceHolder;
    - (MMPlaceHolder *)getPlaceHolder;

v1.0 you can custom or simply use it by

    - (void)showPlaceHolder;
    - (void)showPlaceHolderWithLineColor:(UIColor*)lineColor;
    - (void)showPlaceHolderWithLineColor:(UIColor*)lineColor backColor:(UIColor*)backColor;
    - (void)showPlaceHolderWithLineColor:(UIColor*)lineColor backColor:(UIColor*)backColor arrowSize:(CGFloat)arrowSize ;
    - (void)showPlaceHolderWithLineColor:(UIColor*)lineColor backColor:(UIColor*)backColor arrowSize:(CGFloat)arrowSize lineWidth:(CGFloat)lineWidth;