[TOC]
# **class pygame.BufferProxy**
BufferProxy 是 Surface 对象通过数组协议导出的一个缓冲对象。
BufferProxy() -> BufferProxy
## **属性 & 方法**
* pygame.BufferProxy.parent — 返回被打包输出的对象
* pygame.BufferProxy.length — 输出缓冲区的尺寸,以字节为单位
* pygame.BufferProxy.raw — 一个导出缓冲区的拷贝,存储在单一的字节块中
* pygame.BufferProxy.write() — Write raw bytes to object buffer.
BufferProxy 是 Pygame 支持的一种类型,用于作为 Surface.get\_buffer() 和 Surface.get\_view() 方法的返回值。对于所有版本的 Python,BufferProxy 对象输出一个 C 结构和 Python 级别的数组接口代表其父对象的缓冲区。
对于 CPython2.6 及以后版本,使用了一个新的缓冲区接口输出。在 Pgame 中,BufferProxy 是实现 surfarray 模块(用于通过数组接口访问 Surface 对象的像素数据)的关键。
BufferProxy 实例可以直接通过 Python 代码实现,但无论是作为父对象输出的接口,或者 Python 字典描述的缓冲区布局,该实例(所有的字典项目均基于 Python 级别的数组接口映射方式)均包含以下键:
| **键** | **值(类型)** | **含义** |
| --- | --- | --- |
| “shape” | 元组 | 1\. 元祖中每个元素表示数组每个维度的长度 2. 元祖的长度表示数组的维数 |
| “typestr” | 字符串 | 用 3 个字符的字符串来描述数组元素的类型: — 第 1 个字符表示字节顺序:’’ 表示大端;’|’ 表示不适用 — 第 2 个字符表示元素的类型:’i’ 表示带符号整形;’u’ 表示无符号整形;’f’ 表示浮点型;’V’ 表示字节块 — 第 3 个字符表示每个元素的字节数:1 ~ 9 个字节 例如:”<u4” 表示无符号 4 个字节的小端整数,通常是 32 位像素的电脑;而 “|V3” 则表示 24 位像素(但没有对应的整数) |
| “data” | 元组 | 用一个 2 元祖表示物理缓冲区的起始地址和只读标志:起始地址是整型值,而只读标志是布尔类型(False 表示可写入,True 表示只读) |
| “strides”(可选) | 元组 | 描述步进的信息,需要非 C 的相邻数组,但该元祖的长度必须与 “shape” 相匹配 |
| “parent”(可选) | 对象 | 输出对象,用于保持当缓冲区可见时父对象存活 |
| “before”(可选) | 回调函数 | 1\. 指定当 BufferProxy 实例输出缓冲区时的回调函数 2. 如果指定 “parent” 对象,该回调函数作为参数传递,否则参数为 None 3. 该回调函数对设置父对象锁有用 |
| “after”(可选) | 回调函数 | 1\. 指定当 BufferProxy 实例输出缓冲区被释放时的回调函数 2. 如果指定 “parent” 对象,该回调函数作为参数传递,否则参数为 None 3. 该回调函数对释放父对象锁有用 |
该 BufferProxy 类支持的子类,实例变量和弱引用。
## **属性 & 方法详解**
### **parent**
返回被打包输出的对象。
parent -> Surface parent ->
返回该 BufferProxy 的 Surface 对象,或者调用 BufferProxy 的对象。
### **length**
输出缓冲区的尺寸,以字节为单位。
length -> int
导出数据的有效字节数。对于不连续(不在同一块内存中)数据来说,间隙中的字节并不在计算范围内。该属性等同于 C 的 Py\_buffer 结构的 len 字段。
### **raw**
一个导出缓冲区的拷贝,存储在单一的字节块中。
raw -> bytes
将缓冲区的数据拷贝为 str 或 bytes 对象,导出数据中的任何间隙将被删除。
### **write()**
写入原始字节到缓冲区对象中。
write(buffer, offset=0)
覆盖写入父对象中的字节数据。数据必须是连续的 C 或 F,否则将抛出 ValueError 异常。
buffer 参数是 str 或 bytes 对象。
可选参数 offset 指定缓冲区内开始覆盖的起始偏移位置,以字节为单位。
如果偏移量为负数或大于等于缓冲区的尺寸,将抛出 IndexException 异常。
如果 len(buffer) > proxy.length + offset,将抛出 ValueError 异常。
- 一、Python基础
- 1. 序言
- 1.1 Python简介
- 1.2 安装和使用IDE
- 1.3 语言特性和基础概念
- 2. 基本数据类型
- 2.2 字符串型
- 2.2.2 ASCII简介
- 2.2.4 字符串常用函数
- 3. 条件分支
- 3.3 闲聊条件判断和运算符优先级
- 10.正则表达式
- 【降龙十八章】Python小技巧
- 18.1 学习网址
- 18.2 PIP切换源
- 18.3 使用whl来安装
- 【工具优化】IDE优化技巧
- Anaconda
- Jupyter Notebook 的 Markdown 添加大纲
- Jupyter Notebook中图片缩放和居左
- Anaconda设置环境变量
- Pycharm
- PyCharm新建文档配置
- 设置字体和字号
- 设置主题和字体配色
- 保存和导入配置
- 设置对选择内容自动添加引号
- 推荐安装的插件
- Markdown
- 表格格式
- 二、Python进阶
- copy和deepcopy
- 《零基础入门学习 Python 》【小甲鱼版】
- 001.和Python的第一次接触+习题复习
- 002.用Python设计的第一个游戏 +习题复习
- Pygame详解
- Pygame详解:前言
- Pygame详解(一):Color类
- Pygame详解(二):display 模块
- Pygame详解(三):draw 模块
- Pygame详解(四):event 模块
- Pygame详解(五):font 模块
- Pygame详解(六):image 模块
- Pygame详解(七):key 模块
- Pygame详解(八):locals 模块
- Pygame详解(九):mixer 模块
- Pygame详解(十):mouse 模块
- Pygame详解(十一):Rect 对象
- Pygame详解(十二):Surface 对象
- Pygame详解(十三):time 模块
- Pygame详解(十四):music 模块
- Pygame详解(十五):pygame 模块
- Pygame详解(十六):cursors 模块
- Pygame详解(十七):joystick 模块
- Pygame详解(十八):mask 模块
- Pygame详解(二十一):BufferProxy 对象
- Pygame详解(二十三):gfxdraw 模块
- Pygame详解(二十五):Overlay 对象
- Pygame详解(二十八):sndarray 模块
- Pygame详解(三十一):camera 模块
- Pygame详解(三十二):cdrom 模块
- Pygame详解(三十六):version 模块
- pygame rect相关知识
- Tkinter详解
- Tkinter 组件详解(一):Label
- Tkinter 组件详解(二):Button