Masonry的使用

Masonry是一个轻量级的布局框架,拥有自己的描述语法,采用更优雅的链式语法封装自动布局,简洁明了并具有高可读性,而且同时支持 iOS 和 Max OS X。Masonry是一个用代码写iOS或OS界面的库,可以代替Auto layout。Masonry的github地址:https://github.com/SnapKit/Masonry

本章内容

- Masonry配置

- Masonry使用

- Masonry实例

Masonry配置

- 推荐使用pods方式引入类库,pod 'Masonry',若不知道pod如何使用,情况我的另一篇文章: 提高ios开发效率的工具

- 引入头文件 #import "Masonry.h"

Masonry使用讲解

mas_makeConstraints 是给view添加约束,约束有几种,分别是边距,宽,高,左上右下距离,基准线。添加过约束后可以有修正,修正有offset(位移)修正和multipliedBy(倍率)修正。

语法一般是 make.equalTo or make.greaterThanOrEqualTo or make.lessThanOrEqualTo + 倍数和位移修正。

注意点1: 使用 mas_makeConstraints方法的元素必须事先添加到父元素的中,例如[self.view addSubview:view];

注意点2: masequalTo 和 equalTo 区别:masequalTo 比equalTo多了类型转换操作,一般来说,大多数时候两个方法都是 通用的,但是对于数值元素使用mas_equalTo。对于对象或是多个属性的处理,使用equalTo。特别是多个属性时,必须使用equalTo,例如 make.left.and.right.equalTo(self.view);

注意点3: 注意到方法with和and,这连个方法其实没有做任何操作,方法只是返回对象本身,这这个方法的左右完全是为了方法写的时候的可读性 。make.left.and.right.equalTo(self.view);和make.left.right.equalTo(self.view);是完全一样的,但是明显的加了and方法的语句可读性 更好点。

Masonry初级使用例子

// exp1: 中心点与self.view相同,宽度为400*400

-(void)exp1{

UIView *view = [UIView new];

[view setBackgroundColor:[UIColor redColor]];

[self.view addSubview:view];

[view mas_makeConstraints:^(MASConstraintMaker *make) {

make.center.equalTo(self.view);

make.size.mas_equalTo(CGSizeMake(400,400));

}];

}

//exp2: 上下左右边距都为10

-(void)exp2{

UIView *view = [UIView new];

[view setBackgroundColor:[UIColor redColor]];

[self.view addSubview:view];

[view mas_makeConstraints:^(MASConstraintMaker *make) {

make.edges.equalTo(self.view).with.insets(UIEdgeInsetsMake(10, 10, 10, 10));

//  make.left.equalTo(self.view).with.offset(10);

//  make.right.equalTo(self.view).with.offset(-10);

//  make.top.equalTo(self.view).with.offset(10);

//  make.bottom.equalTo(self.view).with.offset(-10);

}];

}

//exp3 让两个高度为150的view垂直居中且等宽且等间隔排列 间隔为10

-(void)exp3{

UIView *view1 = [UIView new];

[view1 setBackgroundColor:[UIColor redColor]];

[self.view addSubview:view1];

UIView *view2 = [UIView new];

[view2 setBackgroundColor:[UIColor redColor]];

[self.view addSubview:view2];

[view1 mas_makeConstraints:^(MASConstraintMaker *make) {

make.centerY.mas_equalTo(self.view.mas_centerY);

make.height.mas_equalTo(150);

make.width.mas_equalTo(view2.mas_width);

make.left.mas_equalTo(self.view.mas_left).with.offset(10);

make.right.mas_equalTo(view2.mas_left).offset(-10);

}];

[view2 mas_makeConstraints:^(MASConstraintMaker *make) {

make.centerY.mas_equalTo(self.view.mas_centerY);

make.height.mas_equalTo(150);

make.width.mas_equalTo(view1.mas_width);

make.left.mas_equalTo(view1.mas_right).with.offset(10);

make.right.equalTo(self.view.mas_right).offset(-10);

}];

}

Masonry高级使用例子1

iOS计算器使用Masorny布局:

IOS自适应前段库-Masonry的使用

//高级布局练习 ios自带计算器布局

-(void)exp4{

//申明区域,displayView是显示区域,keyboardView是键盘区域

UIView *displayView = [UIView new];

[displayView setBackgroundColor:[UIColor blackColor]];

[self.view addSubview:displayView];

UIView *keyboardView = [UIView new];

[self.view addSubview:keyboardView];

//先按1:3分割 displView(显示结果区域)和 keyboardView(键盘区域)

[displayView mas_makeConstraints:^(MASConstraintMaker *make) {

make.top.equalTo(self.view.mas_top);

make.left.and.right.equalTo(self.view);

make.height.equalTo(keyboardView).multipliedBy(0.3f);

}];

[keyboardView mas_makeConstraints:^(MASConstraintMaker *make) {

make.top.equalTo(displayView.mas_bottom);

make.bottom.equalTo(self.view.mas_bottom);

make.left.and.right.equalTo(self.view);

}];

//设置显示位置的数字为0

UILabel *displayNum = [[UILabel alloc]init];

[displayView addSubview:displayNum];

displayNum.text = @"0";

displayNum.font = [UIFont fontWithName:@"HeiTi SC" size:70];

displayNum.textColor = [UIColor whiteColor];

displayNum.textAlignment = NSTextAlignmentRight;

[displayNum mas_makeConstraints:^(MASConstraintMaker *make) {

make.left.and.right.equalTo(displayView).with.offset(-10);

make.bottom.equalTo(displayView).with.offset(-10);

}];

//定义键盘键名称,?号代表合并的单元格

NSArray *keys = @[@"AC",@"+/-",@"%",@"÷"

,@"7",@"8",@"9",@"x"

,@"4",@"5",@"6",@"-"

,@"1",@"2",@"3",@"+"

,@"0",@"?",@".",@"="];

int indexOfKeys = 0;

for (NSString *key in keys){

//循环所有键

indexOfKeys++;

int rowNum = indexOfKeys %4 ==0? indexOfKeys/4:indexOfKeys/4 +1;

int colNum = indexOfKeys %4 ==0? 4 :indexOfKeys %4;

NSLog(@"index is:%d and row:%d,col:%d",indexOfKeys,rowNum,colNum);

//键样式

UIButton *keyView = [UIButton buttonWithType:UIButtonTypeCustom];

[keyboardView addSubview:keyView];

[keyView setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];

[keyView setTitle:key forState:UIControlStateNormal];

[keyView.layer setBorderWidth:1];

[keyView.layer setBorderColor:[[UIColor blackColor]CGColor]];

[keyView.titleLabel setFont:[UIFont fontWithName:@"Arial-BoldItalicMT" size:30]];

//键约束

[keyView mas_makeConstraints:^(MASConstraintMaker *make) {

//处理 0 合并单元格

if([key isEqualToString:@"0"] || [key isEqualToString:@"?"] ){

if([key isEqualToString:@"0"]){

[keyView mas_makeConstraints:^(MASConstraintMaker *make) {

make.height.equalTo(keyboardView.mas_height).with.multipliedBy(.2f);

make.width.equalTo(keyboardView.mas_width).multipliedBy(.5);

make.left.equalTo(keyboardView.mas_left);

make.baseline.equalTo(keyboardView.mas_baseline).with.multipliedBy(.9f);

}];

}if([key isEqualToString:@"?"]){

[keyView removeFromSuperview];

}

}

//正常的单元格

else{

make.width.equalTo(keyboardView.mas_width).with.multipliedBy(.25f);

make.height.equalTo(keyboardView.mas_height).with.multipliedBy(.2f);

//按照行和列添加约束,这里添加行约束

switch (rowNum) {

case 1:

{

make.baseline.equalTo(keyboardView.mas_baseline).with.multipliedBy(.1f);

keyView.backgroundColor = [UIColor colorWithRed:205 green:205 blue:205 alpha:1];

}

break;

case 2:

{

make.baseline.equalTo(keyboardView.mas_baseline).with.multipliedBy(.3f);

}

break;

case 3:

{

make.baseline.equalTo(keyboardView.mas_baseline).with.multipliedBy(.5f);

}

break;

case 4:

{

make.baseline.equalTo(keyboardView.mas_baseline).with.multipliedBy(.7f);

}

break;

case 5:

{

make.baseline.equalTo(keyboardView.mas_baseline).with.multipliedBy(.9f);

}

break;

default:

break;

}

//按照行和列添加约束,这里添加列约束

switch (colNum) {

case 1:

{

make.left.equalTo(keyboardView.mas_left);

}

break;

case 2:

{

make.right.equalTo(keyboardView.mas_centerX);

}

break;

case 3:

{

make.left.equalTo(keyboardView.mas_centerX);

}

break;

case 4:

{

make.right.equalTo(keyboardView.mas_right);

[keyView setBackgroundColor:[UIColor colorWithRed:243 green:127 blue:38 alpha:1]];

}

break;

default:

break;

}

}

}];

}

}

本例子使用的baseline去控制高度位置,这似乎不是太准,如果想要精准控制高度位置,可以使用一行一行添加的方法,每次当前行的top去equelTo上一行的bottom。 给个提示:

for(遍历所有行)

for(遍历所以列)

//当前行约束根据上一行去设置

......

下一个例子中,使用上面类似的方法

Masonry高级使用例子2

根据设计图,使用masonry布局:

步骤1

IOS自适应前段库-Masonry的使用

步骤2

IOS自适应前段库-Masonry的使用

步骤1

-(void)createUI{

UIView *titleView = [UIView new];

titleView.backgroundColor = [UIColor redColor];

UIView *caredView = [UIView new];

[self.view addSubview:caredView];

UIView *brifeView = [UIView new];

[self.view addSubview:brifeView];

//self.view

self.view.backgroundColor = [UIColor colorWithWhite:0.965 alpha:1.000];

//thrm

UIImageView *plantThrm = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"defalutPlantReferenceIcon"]];

[self.view addSubview:plantThrm];

[plantThrm mas_makeConstraints:^(MASConstraintMaker *make) {

make.left.and.top.equalTo(self.view).with.offset(10);

}];

//title

[self.view addSubview:titleView];

UIImageView *bgTitleView = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"bg-plant-reference-title"]];

[titleView addSubview:bgTitleView];

[titleView mas_makeConstraints:^(MASConstraintMaker *make) {

make.right.equalTo(self.view.mas_right);

make.left.equalTo(plantThrm.mas_right).with.offset(20);

make.centerY.equalTo(plantThrm.mas_centerY);

}];

[bgTitleView mas_makeConstraints:^(MASConstraintMaker *make) {

make.edges.equalTo(titleView);

}];

UILabel *title = [[UILabel alloc]init];

title.textColor =  [UIColor whiteColor];

title.font = [UIFont fontWithName:@"Heiti SC" size:26];

title.text = _reference.name;

[titleView addSubview:title];

[title mas_makeConstraints:^(MASConstraintMaker *make) {

make.left.equalTo(titleView.mas_left).offset(10);

make.width.equalTo(titleView.mas_width);

make.centerY.equalTo(titleView.mas_centerY);

}];

//植物养护

UILabel *caredTitle = [[UILabel alloc]init];

caredTitle.textColor =  [UIColor colorWithRed:0.172 green:0.171 blue:0.219 alpha:1.000];

caredTitle.font = [UIFont fontWithName:@"Heiti SC" size:10];

caredTitle.text = @"植物养护";

[self.view addSubview:caredTitle];

[caredTitle mas_makeConstraints:^(MASConstraintMaker *make) {

make.top.equalTo(plantThrm.mas_bottom).with.offset(20);

make.left.and.right.equalTo(self.view).with.offset(10);

make.height.mas_equalTo(10);

}];

//将图层的边框设置为圆脚

caredView.layer.cornerRadius = 5;

caredView.layer.masksToBounds = YES;

//给图层添加一个有色边框

caredView.layer.borderWidth = 1;

caredView.layer.borderColor = [[UIColor colorWithWhite:0.521 alpha:1.000] CGColor];

caredView.backgroundColor = [UIColor whiteColor];

[caredView mas_makeConstraints:^(MASConstraintMaker *make) {

make.top.equalTo(caredTitle.mas_bottom).with.offset(5);

make.left.equalTo(self.view.mas_left).with.offset(10);

make.right.equalTo(self.view.mas_right).with.offset(-10);

make.height.equalTo(brifeView);

}];

//植物简介

UILabel *brifeTitle = [[UILabel alloc]init];

brifeTitle.textColor =  [UIColor colorWithRed:0.172 green:0.171 blue:0.219 alpha:1.000];

brifeTitle.font = [UIFont fontWithName:@"Heiti SC" size:10];

brifeTitle.text = @"植物简介";

[self.view addSubview:brifeTitle];

[brifeTitle mas_makeConstraints:^(MASConstraintMaker *make) {

make.top.equalTo(caredView.mas_bottom).with.offset(20);

make.left.and.right.equalTo(self.view).with.offset(10);

make.height.mas_equalTo(10);

}];

//将图层的边框设置为圆脚

brifeView.layer.cornerRadius = 5;

brifeView.layer.masksToBounds = YES;

//给图层添加一个有色边框

brifeView.layer.borderWidth = 1;

brifeView.layer.borderColor = [[UIColor colorWithWhite:0.521 alpha:1.000] CGColor];

brifeView.backgroundColor = [UIColor whiteColor];

[brifeView mas_makeConstraints:^(MASConstraintMaker *make) {

make.top.equalTo(brifeTitle.mas_bottom).with.offset(5);

make.left.equalTo(self.view.mas_left).with.offset(10);

make.right.equalTo(self.view.mas_right).with.offset(-10);

make.bottom.equalTo(self.view.mas_bottom).with.offset(-10);

make.height.equalTo(caredView);

}];

}

完成之后如下图 步骤1

IOS自适应前段库-Masonry的使用

步骤2,在上面的基础上,增加植物养护部分ui构造的代码,思想是,先构造出四行,然后根据每行单独构造出行样式。

//把块拆分为四行

-(void)createIndexUIWithView:(UIView *)view{

//拆分四行

UIView *row1 = [UIView new];

UIView *row2 = [UIView new];

UIView *row3 = [UIView new];

UIView *row4 = [UIView new];

[view addSubview:row1];

[view addSubview:row2];

[view addSubview:row3];

[view addSubview:row4];

[row1 mas_makeConstraints:^(MASConstraintMaker *make) {

make.right.and.left.equalTo(view);

make.height.equalTo(view.mas_height).multipliedBy(0.25);

make.top.equalTo(view.mas_top);

}];

[row2 mas_makeConstraints:^(MASConstraintMaker *make) {

make.right.and.left.equalTo(view);

make.top.equalTo(row1.mas_bottom);

make.height.equalTo(view.mas_height).multipliedBy(0.25);

}];

[row3 mas_makeConstraints:^(MASConstraintMaker *make) {

make.right.equalTo(view.mas_right);

make.top.equalTo(row2.mas_bottom);

make.height.equalTo(view.mas_height).multipliedBy(0.25);

make.left.equalTo(view.mas_left);

}];

[row4 mas_makeConstraints:^(MASConstraintMaker *make) {

make.right.and.left.equalTo(view);

make.top.equalTo(row3.mas_bottom);

make.height.equalTo(view.mas_height).multipliedBy(0.25);

}];

[self createIndexRowUI:PlantReferenceWaterIndex withUIView:row1];

[self createIndexRowUI:PlantReferenceSumIndex withUIView:row2];

[self createIndexRowUI:PlantReferenceTemperatureIndex withUIView:row3];

[self createIndexRowUI:PlantReferenceElectrolyteIndex withUIView:row4];

}

//构造每行的UI

-(void)createIndexRowUI:(PlantReferenceIndex) index withUIView:(UIView *)view{

//index标题

UILabel *indexTitle = [UILabel new];

indexTitle.font = [UIFont fontWithName:@"HeiTi SC" size:14];

indexTitle.textColor = [UIColor colorWithWhite:0.326 alpha:1.000];

[view addSubview:indexTitle];

[indexTitle mas_makeConstraints:^(MASConstraintMaker *make) {

make.left.equalTo(view.mas_left).with.offset(20);

make.centerY.equalTo(view.mas_centerY);

}];

switch (index) {

case PlantReferenceWaterIndex:

{

indexTitle.text = @"水分";

UIImageView * current;

for(int i=1;i<=5;i++){                if(i<_reference.waterIndex){                    current = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_water_light"]];                }else{                    current = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_water_dark"]];                }                [view addSubview:current];                //间距12%,左边留空30%                [current mas_makeConstraints:^(MASConstraintMaker *make) {                    make.left.equalTo(view.mas_right).with.multipliedBy(0.12*(i-1) +0.3);                    make.centerY.equalTo(view.mas_centerY);                }];            }        }              break;        case PlantReferenceSumIndex:        {            indexTitle.text = @"光照";            UIImageView * current;            for(int i=1;i<=5;i++){                if(i<_reference.temperatureIndex){                    current = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_summer_light"]];                }else{                    current = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_summer_dark"]];                }                [view addSubview:current];                //间距12%,左边留空30%                [current mas_makeConstraints:^(MASConstraintMaker *make) {                    make.left.equalTo(view.mas_right).with.multipliedBy(0.12*(i-1) +0.3);                    make.centerY.equalTo(view.mas_centerY);                }];            }        }              break;        case PlantReferenceTemperatureIndex:        {            indexTitle.text = @"温度";            UIImageView * current;            for(int i=1;i<=5;i++){                if(i<_reference.sumIndex){                    current = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_temperature_light"]];                }else{                    current = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_temperature_dark"]];                }                [view addSubview:current];                //间距12%,左边留空30%                [current mas_makeConstraints:^(MASConstraintMaker *make) {                    make.left.equalTo(view.mas_right).with.multipliedBy(0.12*(i-1) +0.3);                    make.centerY.equalTo(view.mas_centerY);                }];            }        }              break;        case PlantReferenceElectrolyteIndex:        {            indexTitle.text = @"肥料";            UIImageView * current;            for(int i=1;i<=5;i++){                if(i<_reference.electrolyteIndex){                    current = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_electolyte_light"]];                }else{                    current = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_electolyte_dark"]];                }                [view addSubview:current];                //间距12%,左边留空30%                [current mas_makeConstraints:^(MASConstraintMaker *make) {                    make.left.equalTo(view.mas_right).with.multipliedBy(0.12*(i-1) +0.3);                    make.centerY.equalTo(view.mas_centerY);                }];            }        }            break;        default:            break;    } } //在步骤1createui的基础上,做了一些微调。 -(void)createUI{    self.title = _reference.name;    UIView *titleView = [UIView new];    UIView *caredView = [UIView new];    [self.view addSubview:caredView];    UITextView *brifeView = [UITextView new];    [self.view addSubview:brifeView];    //self.view    self.view.backgroundColor = [UIColor colorWithWhite:0.965 alpha:1.000];    //thrm    UIImageView *plantThrm = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"defalutPlantReferenceIcon"]];    [self.view addSubview:plantThrm];    [plantThrm mas_makeConstraints:^(MASConstraintMaker *make) {        make.left.and.top.equalTo(self.view).with.offset(10);    }];    //title        [self.view addSubview:titleView];        UIImageView *bgTitleView = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"bg-plant-reference-title"]];    [titleView addSubview:bgTitleView];    [titleView mas_makeConstraints:^(MASConstraintMaker *make) {        make.right.equalTo(self.view.mas_right);        make.left.equalTo(plantThrm.mas_right).with.offset(20);        make.centerY.equalTo(plantThrm.mas_centerY);    }];    [bgTitleView mas_makeConstraints:^(MASConstraintMaker *make) {        make.edges.equalTo(titleView);    }];    UILabel *title = [[UILabel alloc]init];    title.textColor =  [UIColor whiteColor];    title.font = [UIFont fontWithName:@"Heiti SC" size:26];    title.text = _reference.name;    [titleView addSubview:title];    [title mas_makeConstraints:^(MASConstraintMaker *make) {        make.left.equalTo(titleView.mas_left).offset(10);        make.width.equalTo(titleView.mas_width);        make.centerY.equalTo(titleView.mas_centerY);    }];    //植物养护    UILabel *caredTitle = [[UILabel alloc]init];    caredTitle.textColor =  [UIColor colorWithRed:0.172 green:0.171 blue:0.219 alpha:1.000];    caredTitle.font = [UIFont fontWithName:@"Heiti SC" size:10];    caredTitle.text = @"植物养护";    [self.view addSubview:caredTitle];    [caredTitle mas_makeConstraints:^(MASConstraintMaker *make) {        make.top.equalTo(plantThrm.mas_bottom).with.offset(20);        make.left.and.right.equalTo(self.view).with.offset(10);        make.height.mas_equalTo(10);    }];    //植物养护 数据    [self createIndexUIWithView:caredView];    //将图层的边框设置为圆脚    caredView.layer.cornerRadius = 5;    caredView.layer.masksToBounds = YES;    //给图层添加一个有色边框    caredView.layer.borderWidth = 1;    caredView.layer.borderColor = [[UIColor colorWithWhite:0.521 alpha:1.000] CGColor];    caredView.backgroundColor = [UIColor whiteColor];    [caredView mas_makeConstraints:^(MASConstraintMaker *make) {        make.top.equalTo(caredTitle.mas_bottom).with.offset(5);        make.left.equalTo(self.view.mas_left).with.offset(10);        make.right.equalTo(self.view.mas_right).with.offset(-10);        make.height.equalTo(brifeView);    }];    //植物简介    UILabel *brifeTitle = [[UILabel alloc]init];    brifeTitle.textColor =  [UIColor colorWithRed:0.172 green:0.171 blue:0.219 alpha:1.000];    brifeTitle.font = [UIFont fontWithName:@"Heiti SC" size:10];    brifeTitle.text = @"植物简介";    [self.view addSubview:brifeTitle];    [brifeTitle mas_makeConstraints:^(MASConstraintMaker *make) {        make.top.equalTo(caredView.mas_bottom).with.offset(20);        make.left.and.right.equalTo(self.view).with.offset(10);        make.height.mas_equalTo(10);    }];    //将图层的边框设置为圆脚    brifeView.layer.cornerRadius = 5;    brifeView.layer.masksToBounds = YES;    //给图层添加一个有色边框    brifeView.layer.borderWidth = 1;    brifeView.layer.borderColor = [[UIColor colorWithWhite:0.447 alpha:1.000] CGColor];    brifeView.backgroundColor = [UIColor whiteColor];    //文字样式 //    brifeView.textColor = [UIColor colorWithWhite:0.352 alpha:1.000]; //    brifeView.font = [UIFont fontWithName:@"HeiTi SC" size:12];    NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc]init];    paragraphStyle.lineHeightMultiple = 20.f;    paragraphStyle.maximumLineHeight = 25.f;    paragraphStyle.minimumLineHeight = 15.f;    paragraphStyle.alignment = NSTextAlignmentJustified;    NSDictionary *attributes = @{ NSFontAttributeName:[UIFont systemFontOfSize:12], NSParagraphStyleAttributeName:paragraphStyle, NSForegroundColorAttributeName:[UIColor colorWithWhite:0.447 alpha:1.000]};    //植物简介数据    //brifeView.text = _reference.brief;    brifeView.attributedText = [[NSAttributedString alloc] initWithString: _reference.brief attributes:attributes];    [brifeView mas_makeConstraints:^(MASConstraintMaker *make) {        make.top.equalTo(brifeTitle.mas_bottom).with.offset(5);        make.left.equalTo(self.view.mas_left).with.offset(10);        make.right.equalTo(self.view.mas_right).with.offset(-10);        make.bottom.equalTo(self.view.mas_bottom).with.offset(-10);        make.height.equalTo(caredView);    }]; }

完成之后如下图 步骤2

IOS自适应前段库-Masonry的使用

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容