图片数据是我自己编写的Django服务器上以Base64编码的图片,在本地接收后解码为图片显示在QLabel中。
服务器代码:
def query_userinfo(request):
name = request.POST.get('name')
name_check = charge.objects.get(name = name)
dest = base64.b64encode(name_check.img)
returnData = {
'code':'0',
'msg':'success',
'name':name,
'mobile':name_check.phonenum,
'iccard':name_check.icnum,
'pic':dest.decode('utf-8')
}
return HttpResponse(json.dumps(returnData), content_type="application/json")
本地一开始的代码,这个代码无法再QLabel中显示图片:
def query_userinfo(self):
postData = {
'name':self.lineEdit_3.text()
}
r = requests.post("http://127.0.0.1:8000/app01/queryuserinfo/", data=postData)
json_data = json.loads(r.text)
self.mobile_show.setText(json_data.get('mobile'))
self.precard_show.setText(json_data.get('iccard'))
pic_data = json_data.get('pic').encode('utf-8')
pixmap = QPixmap(151,171)
ba = QtCore.QByteArray.fromBase64(pic_data)
pixmap.loadFromData(ba)
self.pic_show.setPixmap(pixmap)
return None
无法显示的原因就是QLabel的大小和我的图片不匹配,后来对QPixmap调用Scaled函数后依旧不行。
pixmap.scaled(151, 171, aspectRatioMode = Qt.IgnoreAspectRatio)
后来才发现添加
self.pic_show.setScaledContents(True)
这行代码后就可以正确显示。这个函数的意义就在于是否将缩放其内容以填充所有可用空间。当启用时,标签显示一个像素图,它将缩放像素图以填充可用空间。该属性的默认值是False。