Difference between revisions of "love.window.fromPixels (简体中文)"

(english -> 简体中文)
 
(3 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{newin|[[0.9.2]]|092|type=function}}
+
{{newin (简体中文)|[[0.9.2]]|092|type=函数}}
 
把数字从像素单位转换为像素密度无关单位。
 
把数字从像素单位转换为像素密度无关单位。
  
窗口内的像素密度可能比窗口的“大小”更大(或更小)。例如通过[[love.window.setMode]] 启用在Mac OS X 上的Retina屏幕的<code>highdpi</code> ,窗口会使用相同的800x600的物理窗口大小,但窗口的内部区域使用1600x1200像素。那样的话<code>love.window.fromPixels(1600)</code> 将返回 <code>800</code> 。
+
窗口内的设备像素可能比窗口的大小更大(或更小)。若在Mac OS X 上的Retina屏幕通过[[love.window.setMode]] 启用<code>highdpi</code> ,窗口会占用800x600的窗口大小,但窗口的内部区域使用1600x1200像素。
 +
 
 +
在这种情况下<code>love.window.fromPixels(1600)</code> 将返回 <code>800</code> 。
 +
 
 +
 
 +
这个函数把以像素为单位的坐标转换为屏幕上点的坐标。[[love.window.toPixels]]函数则相反。在Mac OS X 和 iOS平台上,<code>highdpi</code>的window flag必须被启用,以使用Retina屏幕的全像素密度。
  
这个函数转换坐标从像素到用户期望的在屏幕上显示的大小。[[love.window.toPixels]]函数则相反。在Mac OS X 和 iOS平台上,<code>highdpi</code>的window flag必须被启用,以使用Retina屏幕的全像素密度。
 
 
这个标志在Windows 和 Linux上不产生影响,但在Android上总是启用的。
 
这个标志在Windows 和 Linux上不产生影响,但在Android上总是启用的。
  
大多数的 LÖVE 函数 return values and expect arguments in terms of pixels rather than density-independent units.
+
大多数的 LÖVE 函数返回值及参数用的是像素单位而不是设备无关单位(DIP)。
  
== Function ==
+
== 函数 ==
=== Synopsis ===
+
=== 基础使用 ===
 
<source lang="lua">
 
<source lang="lua">
 
value = love.window.fromPixels( pixelvalue )
 
value = love.window.fromPixels( pixelvalue )
 
</source>
 
</source>
=== Arguments ===
+
=== 参数 ===
{{param|number|pixelvalue|A number in pixels to convert to density-independent units.}}
+
{{param|number|pixelvalue|要转换成设备无关单位的一个以像素为单位的数字。}}
=== Returns ===
+
=== 返回值 ===
{{param|number|value|The converted number, in density-independent units.}}
+
{{param|number|value|转换后的数字,以设备无关单位为单位。}}
  
== Function ==
+
== 函数 ==
=== Synopsis ===
+
=== 基础使用 ===
 
<source lang="lua">
 
<source lang="lua">
 
x, y = love.window.fromPixels( px, py )
 
x, y = love.window.fromPixels( px, py )
 
</source>
 
</source>
=== Arguments ===
+
=== 参数 ===
{{param|number|px|The x-axis value of a coordinate in pixels.}}
+
{{param|number|px|以像素为单位的横坐标。}}
{{param|number|py|The y-axis value of a coordinate in pixels.}}
+
{{param|number|py|以像素为单位的纵坐标。}}
=== Returns ===
+
=== 返回值 ===
{{param|number|x|The converted x-axis value of the coordinate, in density-independent units.}}
+
{{param|number|x|转换后的横坐标,以设备无关单位为单位。}}
{{param|number|y|The converted y-axis value of the coordinate, in density-independent units.}}
+
{{param|number|y|转换后的纵坐标,以设备无关单位为单位。}}
  
== Notes ==
+
== 备注 ==
The units of [[love.graphics.getWidth]], [[love.graphics.getHeight]], [[love.mouse.getPosition]], mouse events, [[love.touch.getPosition]], and touch events are always in terms of pixels.
+
[[love.graphics.getWidth]], [[love.graphics.getHeight]], [[love.mouse.getPosition]],鼠标事件,[[love.touch.getPosition]],以及触摸事件总是以像素为单位的。
  
== See Also ==
+
== 参见 ==
* [[parent::love.window]]
+
* [[parent::love.window (简体中文)]]
* [[love.window.toPixels]]
+
* [[love.window.toPixels (简体中文)]]
* [[love.window.getPixelScale]]
+
* [[love.window.getPixelScale (简体中文)]]
* [[love.window.setMode]]
+
* [[love.window.setMode (简体中文)]]
* [[Config Files]]
+
* [[Config Files (简体中文)]]
  
 
[[Category:Functions]]
 
[[Category:Functions]]
{{#set:Description=Converts a number from pixels to density-independent units.}}
+
{{#set:Since=092}}
== Other Languages ==
+
{{#set:PrettySince=0.9.2}}
 +
{{#set:Description=把以像素为单位的数字转换为设备无关单位。}}
 +
== 其他语言 ==
 
{{i18n|love.window.fromPixels}}
 
{{i18n|love.window.fromPixels}}

Latest revision as of 14:58, 14 March 2018

自 LÖVE 0.9.2 可以使用
此 函数 在早期版本中不受支持.

把数字从像素单位转换为像素密度无关单位。

窗口内的设备像素可能比窗口的大小更大(或更小)。若在Mac OS X 上的Retina屏幕通过love.window.setMode 启用highdpi ,窗口会占用800x600的窗口大小,但窗口的内部区域使用1600x1200像素。

在这种情况下love.window.fromPixels(1600) 将返回 800


这个函数把以像素为单位的坐标转换为屏幕上点的坐标。love.window.toPixels函数则相反。在Mac OS X 和 iOS平台上,highdpi的window flag必须被启用,以使用Retina屏幕的全像素密度。

这个标志在Windows 和 Linux上不产生影响,但在Android上总是启用的。

大多数的 LÖVE 函数返回值及参数用的是像素单位而不是设备无关单位(DIP)。

函数

基础使用

value = love.window.fromPixels( pixelvalue )

参数

number pixelvalue
要转换成设备无关单位的一个以像素为单位的数字。

返回值

number value
转换后的数字,以设备无关单位为单位。

函数

基础使用

x, y = love.window.fromPixels( px, py )

参数

number px
以像素为单位的横坐标。
number py
以像素为单位的纵坐标。

返回值

number x
转换后的横坐标,以设备无关单位为单位。
number y
转换后的纵坐标,以设备无关单位为单位。

备注

love.graphics.getWidth, love.graphics.getHeight, love.mouse.getPosition,鼠标事件,love.touch.getPosition,以及触摸事件总是以像素为单位的。

参见


其他语言