微信小程序 本地背景图片设置

微信小程序 本地背景图片设置,第1张

1、背景图片设置可以用服务器上的图片。

2、也可以将本地图片转成base64的。

wxml:

<view class="topview-left" style="background-image: url({{background}})mode='scaleToFill'"/>

js:

data: {

    background: "肢山判/style/images/icon_coupon_backgroud.png",

  },

/**

  * 生命周期函数--监听页面加载

  */

  onLoad: function(options) {

    //设置背景图片

    let base64 = wx.getFileSystemManager().readFileSync(this.data.background, 'base64')

    this.setData({

      'background': 'data:image/pngbase64,' + base64

    })

    //设置导航栏标题

    wx.setNavigationBarTitle({

      title: '下发优惠券'

    })

  },

wxss:

.topview-left {

  display: flex

  flex-direction: column

  align-items: center

  justify-content: center

  width: 30%

  height: 113px

  background-repeat: no-repeat/** 不重复*/

  background-size: 100% 100%

  background-image: url('data:image/pngbase64,base64码')/** 添加背景图片的*/

}

3、也可以直接设置定位实现。

         <view style="display: flexalign-items: centertext-align:centerjustify-content: centermargin-bottom:10px">

               <image src="/pagesChronic/images/icon_case_background.png" style="height:26pxwidth:167pxposition:absolute"></image>

           历改     <text style="position: relativecolor:#FF9721">评价</text>唯轮

           </view>

效果:

本文分析对比了各种更改UIView背景的方法。当然,背景是根据一个图片来的(非纯色)。

1.图片会自动拉伸到屏幕view的大小(加一个uiimageview在uiview上面)

[objc] view plaincopy

UIImageView* imageView = [[UIImageView alloc] initWithFrame:view.bounds]

imageView.image = [[UIImage imageNamed:@"name.png"] stretchableImageWithLeftCapWidth:left topCapHeight:top]

[view addSubview:imageView]

这种方式,如果原始图片大小不够(小于view的大小),可以拉伸,在view释放后也没有什么内存保留。

2.通过图片来生成UIColor设置view的backgroundColor(图片不会拉伸到屏幕view的含镇大小)

1.imageNamed方式

[objc] view plaincopy

view.backgroundColor = [UIColor colorWithPatternImage:[UIImage imageNamed:@"name.png"]]

2.contentOfFile方式

[objc] view plaincopy

NSString* path = [[NSBundle mainBundle] pathForResource:@"name" ofType:@"png"]

view.backgroundColor = [UIColor colorWithPatternImage:[UIImage imageWithContentsOfFile:path]

这两种方式都会在生成color时占用大量的内存(原始图片的n倍,这个n可能会达到几千的程度)。而且如果图察圆片大小不够,就会按照原始大小一个一个u画过去,也就是不会自动拉伸。1和2的区别在于,view释放后,1中的color并不会跟着释放,而是一直存在于内存中(当然,再次根据这个图片生成color时并不会再次申请内存了),而2中的color就会随着view的释放而释放。

3..quartzCore方式(图片会自动拉伸到屏幕view的大小)

[objc] view plaincopy

UIImage *image = [UIImage imageNamed:@"name.png"]

view.layer.contents = (id) image.CGImage    //谈没粗 如果需要背景透明加上下面这句

view.layer.backgroundColor = [UIColor clearColor].CGColor

这种方式会自动拉伸图片,而且没有额外内存占用。

综上,推荐第三种方式来根据图片设置背景色。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/bake/11981209.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存