Python游戏引擎开发(七):绘制矢量图
今天来完毕绘制矢量图形。
没有读过前几章的同学,请先阅读前几章:
Python游戏引擎开发(五):Sprite精灵类和鼠标事件
Graphics类
首先我们创建Graphics
类用于创建矢量图形:
class Graphics(DisplayObject):
def __init__(self):
super(Graphics, self).__init__()
# 存储全部图形数据的列表
self.__drawingList = []
# 用于储存当前图形数据
self.__currentGraphics = None
因为我们的窗体界面是在不断清除。然后重绘的,所以增加__drawingList
属性来储存全部图形的数据。而__currentGraphics
用于储存当前图形数据。
在flash
中,我们使用beginFill
方法来下达開始绘制命令。增加该方法:
def beginFill(self, color = "transparent", alpha = 1):
if color == "transparent":
alpha = 0
self.__currentGraphics = {
"path" : QtGui.QPainterPath(),
"lineAlpha" : 255,
"lineWidth" : None,
"lineColor" : None,
"fillColor" : color,
"fillAlpha" : 255 * alpha,
"joins" : None,
"caps" : None,
"miterLimit" : None
}
開始绘制命令须要例如以下几个參数:图形填充色、填充色透明度。
在上面的代码中,我们初始化了__currentGraphics
属性。能够看到,他是一个dict
对象。当中的path
成员是一个QPainterPath
对象。这个对象来自Qt
,通过调用这个类中的一些方法,能够创建一些图形,然后调用QPainter
的drawPath
方法就能够把这个对象里创建的全部图形画出来。
增加endFill
方法。用于把当前图形保存到__drawingList
中,保存到__drawingList
后。就能够使其显示出来:
def endFill(self):
if not self.__currentGraphics:
return
self.__currentGraphics["path"].setFillRule(QtCore.Qt.WindingFill)
self.__drawingList.append(self.__currentGraphics)
然后是_show
方法,在前面的章节中介绍过,每一个显示在界面上的对象都有这种方法,用于显示自身:
def _show(self, c):
for item in self.__drawingList:
if not isinstance(item, dict):
return
path = item["path"]
if not path:
continue
lineWidth = item["lineWidth"]
lineColor = item["lineColor"]
fillColor = item["fillColor"]
joins = item["joins"]
caps = item["caps"]
miterLimit = item["miterLimit"]
fillAlpha = item["fillAlpha"]
lineAlpha = item["lineAlpha"]
brush = None
pen = QtGui.QPen()
c.save()
if lineWidth:
pen.setWidth(lineWidth)
else:
pen.setWidth(0)
if lineColor:
color = getColor(lineColor)
if isinstance(color, QtGui.QColor):
if lineAlpha:
color.setAlpha(lineAlpha)
pen.setColor(color)
else:
pen.setColor(getColor("transparent"))
if joins:
pen.setJoinStyle(joins)
if caps:
pen.setCapStyle(caps)
if miterLimit:
pen.setMiterLimit(miterLimit)
if fillColor:
color = getColor(fillColor)
if fillAlpha and hasattr(color, "setAlpha"):
color.setAlpha(fillAlpha)
brush = QtGui.QBrush(color)
brush.setStyle(QtCore.Qt.SolidPattern)
c.setBrush(brush)
c.setPen(pen)
c.drawPath(path)
c.restore()
当中,我们遍历了__drawingList
,从中读取每一个图形数据,然后依据数据进行一些图形样式设置。最后drawPath
画出图形。
上面的代码主要完毕了基础的一些部分,眼下我们仅仅有開始画图和结束画图命令。
还差设置样式以及增加图形的命令,通过下面代码增加:
def lineStyle(self, thickness = 1, color = "black", alpha = 1, joints = None, caps = None, miterLimit = 3):
if not self.__currentGraphics:
return
if color == "transparent":
alpha = 0
if joints == JoinStyle.ROUND:
joints = QtCore.Qt.RoundJoin
elif joints == JoinStyle.MITER:
joints = QtCore.Qt.MiterJoin
elif joints == JoinStyle.BEVEL:
joints = QtCore.Qt.BevelJoin
if caps == CapsStyle.NONE:
caps = QtCore.Qt.FlatCap
elif caps == CapsStyle.SQUARE:
caps = QtCore.Qt.SquareCap
elif caps == CapsStyle.ROUND:
caps = QtCore.Qt.RoundCap
self.__currentGraphics["lineWidth"] = thickness
self.__currentGraphics["lineColor"] = color
self.__currentGraphics["lineAlpha"] = 255 * alpha
self.__currentGraphics["joints"] = joints
self.__currentGraphics["caps"] = caps
self.__currentGraphics["miterLimit"] = miterLimit
def moveTo(self, x, y):
if not self.__currentGraphics:
return
self.__currentGraphics["path"].moveTo(x, y)
def lineTo(self, x, y):
if not self.__currentGraphics:
return
self.__currentGraphics["path"].lineTo(x, y)
def drawRect(self, x, y, width, height):
if not self.__currentGraphics:
return
self.__currentGraphics["path"].addRect(x, y, width, height)
def drawCircle(self, x, y, radius):
self.drawEllipse(x - radius, y - radius, radius * 2, radius * 2)
def drawEllipse(self, x, y, width, height):
if not self.__currentGraphics:
return
self.__currentGraphics["path"].addEllipse(x, y, width, height)
有了这些命令,就能够进行画图操作了。
Sprite上使用Graphics
Graphics
主要是在Sprite
上使用,例如以下代码所看到的:
layer = Sprite()
layer.graphics.beginFill("#FF0000")
layer.graphics.drawRect(0, 0, 200, 200)
layer.graphics.endFill()
addChild(layer)
可见我们须要为Sprite
增加一个graphics
属性,用于操作矢量图形,所以在Sprite
构造器中增加例如以下代码:
self.graphics = new Graphics()
self.graphics.parent = self
通过上面的这些命令,我们就能够创建出很多不同的矢量图形:
绘制矢量图的功能就搞定了~如有不懂之处,欢迎留言。
至此,引擎基本功能就实现了
Github地址:https://github.com/yuehaowang/pylash_engine
欢迎大家继续关注我的博客
转载请注明出处:Yorhom’s Game Box
Python游戏引擎开发(七):绘制矢量图的更多相关文章
- Python游戏引擎开发(五):Sprite精灵类和鼠标事件
本次来实现Sprite类和鼠标事件. 说起这个Sprite啊,涉及过2D游戏研究领域的看官应该都听说过它. 它中文原意是"精灵",只是在不同人的眼中,它所表示的意义不同. 比方说在 ...
- 【Cocos2d-x游戏引擎开发笔记(25)】XML解析
原创文章,转载请注明出处:http://blog.csdn.net/zhy_cheng/article/details/9128819 XML是一种非常重要的文件格式,由于C++对XML的支持非常完善 ...
- 【译】在Asp.Net中操作PDF - iTextSharp - 绘制矢量图
原文 [译]在Asp.Net中操作PDF - iTextSharp - 绘制矢量图 在上一篇iTextSharp文章中讲述了如何将现有的图片插入PDF中并对其进行操作.但有时,你需要在PDF中绘制不依 ...
- 推荐一些好用的 HTML5 & JavaScript 游戏引擎开发库
推荐一些好用的 HTML5 & JavaScript 游戏引擎开发库 0. 引言 如果你是一个游戏开发者,并且正在寻找一个可以与 JavaScript 和 HTML5 无缝工作的游戏引擎.那么 ...
- 【python】pandas & matplotlib 数据处理 绘制曲面图
Python matplotlib模块,是扩展的MATLAB的一个绘图工具库,它可以绘制各种图形 建议安装 Anaconda后使用 ,集成了很多第三库,基本满足大家的需求,下载地址,对应选择pytho ...
- 25 个超棒的 HTML5 & JavaScript 游戏引擎开发库
就像在汽车中,引擎完成主要的工作,使汽车看起来不可思议.游戏引擎同理,游戏开发者完成细节的工作,使游戏看起来真实.吸引人眼球.游戏引擎负责其余的事情.早期,游戏开发者通常从草图做起,花费高昂,且不容易 ...
- Photoshop 基础七 位图 矢量图 栅格化
矢量图(CorelDraw)不是像素组成的,放大不会失真,体积小,颜色比较单一.由直线.曲线构成,画一些直线.曲线.多边形.图标. 位图(Photoshop画的就是位图),又像素组成,放大失真,放的越 ...
- Qt使用QPainter绘制矢量图并保存为svg文件
位图和矢量图: Bitmap: Usually a larger file size Cannot be enlarged into a higher resolution as the image ...
- 【Android LibGDX游戏引擎开发教程】第06期:图形图像的绘制(下)图片整合工具的使用
在上一篇文章中,我们提到了图片必须是2的n次方的问题.但是随着Libgdx的不断完善和发展,使用一些工具就 可以很好的解决了这样一个问题,但是它的功能又不仅仅只限于此,那么下面就来让我们看看Textu ...
随机推荐
- jQuery源码浅析
这几天看了下jQuery源码,有些收获,解答了我以前对jQuery的疑问,现在我把收获分享给大家. 一.jQuery为何弄成自执行函数,以及为何在引用了jquery文件之后,可以通过$或jQuery来 ...
- vue-cli中引入jquery方法
这里有个详解,当然,仅仅是安装jq的话下面这个办法就够了.传送门 在webpack.base.conf.js里加入 var webpack = require("webpack") ...
- nginx静态资源浏览器缓存
1.缓存介绍 作用:提升用户体验,减少服务器压力 浏览器无缓存:浏览器发起请求->无缓存->请求WEB服务器->web服务器检查是否有更新(没有更新返回304)->呈现 浏览器 ...
- Shiro源码分析之Subject和SecurityManager
Subject 毫无疑问,Subject是Shiro最重要的一个概念. “Subject”只是一个安全术语,意味着应用程序用户的特定于安全性的“视图”.Shiro Subject实例代表单个应用程序用 ...
- 一个Bean属性拷贝的工具类
package com.fpi.spring.qaepb.cps.util; import java.beans.IntrospectionException; import java.beans.P ...
- maven "Generating project in Batch mode"问题的解决
在maven的五分钟入门里面,有这样一个命令: mvn archetype:generate -DgroupId=com.mycompany.app -DartifactId=my-app -Darc ...
- 北邮校赛 H. Black-white Tree (猜的)
H. Black-white Tree 2017- BUPT Collegiate Programming Contest - sync 时间限制 1000 ms 内存限制 65536 KB 题目描述 ...
- 【BZOJ 1478】 1478: Sgu282 Isomorphism (置换、burnside引理)
1478: Sgu282 Isomorphism Description 给 定一个N 个结点的无向完全图( 任意两个结点之间有一条边), 现在你可以用 M 种颜色对这个图的每条边进行染色,每条边必须 ...
- Java小对象的解决之道——对象池(Object Pool)的设计与应用
一.概述 面向对象编程是软件开发中的一项利器,现已经成为大多数编程人员的编程思路.很多高级计算机语言也对这种编程模式提供了很好的支持,例如C++.Object Pascal.Java等.曾经有大量的软 ...
- HZAU 1201 Friends(树形DP)
[题目链接] http://acm.hzau.edu.cn/problem.php?id=1201 [题目大意] 给出一棵树,问每个节点距离六个点以内的点有几个 [题解] 定根维护树形DP,Dw[x] ...