<Win32_15>用纯C语言来实现WP8中磁贴动态翻转的功能「建议收藏」

今年年初入手了一部诺基亚新款WP8手机——Lumia620经典蓝,用起来感觉很不错,很流畅、界面很清新到现在,用了大概有大半年时间了,一直很好奇WP8中磁贴动态翻转的实现算法——使用过WP8手机的朋友都知道,这个功能很有3D的效果,看起来感觉很不错但是,它到底是如何实现的呢? 今儿,我就来和大家一起剖析一下它的实现细节WP8中磁贴动态翻转功能细节:(1)将当

大家好,又见面了,我是你们的朋友全栈君。

本文由BlueCoder编写   转载请说明出处:

http://blog.csdn.net/crocodile__/article/details/10486095

我的邮箱:bluecoder@yeah.net    欢迎大家和我交流编程心得

我的微博:BlueCoder_黎小华    欢迎光临^_^

今年年初入手了一部诺基亚新款WP8手机——Lumia 620 经典蓝,用起来感觉很不错,很流畅、界面很清新

<Win32_15>用纯C语言来实现WP8中磁贴动态翻转的功能「建议收藏」

到现在,用了大概有大半年时间了,一直很好奇WP8中磁贴动态翻转的实现算法——使用过WP8手机的朋友都知道,这个功能很有3D的效果,看起来感觉很不错

但是,它到底是如何实现的呢?

 

今儿,我就来和大家一起剖析一下它的实现细节


WP8中磁贴动态翻转功能细节

(1)将当前图标逐渐缩小(这个缩小的倍率很讲究)

(2)当前图标缩小到一定程度——基本上看不太清楚的时候——就变换另外一张图标

(3)将另外一张图标逐渐放大,直至和原图标大小一致为止

(4)停顿一会儿,继续(1)、(2)、(3)的操作

由此,可见这个看似有3D效果的磁贴翻转功能也就是使用2D技术实现的——毕竟是在一个平面上——但是这个过程比较快,人的肉眼有记忆推迟特点,因此看起来很连贯,就像是将一张图360°翻转过来一样(其实和看视频的原理差不多)


使用过WP8手机的朋友应该都知道”天气通”这个应用吧,它可以产生磁贴放到WP8手机桌面中,并能实现翻转功能,我也就借用这个应用的图标来模拟

下面来看看,我模拟的程序的实现效果:

<Win32_15>用纯C语言来实现WP8中磁贴动态翻转的功能「建议收藏」

 

 

怎么样,还不错吧?呵呵^_^

 

…………

 

 

功能细节大家知道了,可是我们如何用win32纯c语言来实现呢?

OK,我的对策是“对症下药”

<1>首先必须实现缩放位图的功能,这个可以使用StretchBlt这个方法(熟悉Win32的应该知道这个函数吧),它可以按照指定的大小来缩放这个位图

<2>其次,所谓”逐渐缩放”、”停顿一会儿”——当然第一时间想到的就是计时器和Sleep这个函数来实现

 

 

使用到的技术主要就是这两个,下面着重讲解一下具体的代码细节:

<1>变量浏览

//全局变量(用来控制每一次缩放的大小,注意:只是缩放位图的高度、宽度不变)
int		height[] = {144, 88, 32, 10, 75, 137, 200};

 

//回调函数中的静态局部变量
static HBITMAP	hBmp[2];			//存放正反面位图句柄
static SIZE		sBmp, sClient;		//位图大小、客户区大小(用于缩放)
static POINT	ptBmp;				//位图位置(保证始终居中显示)
static int		curIndex, isFirst;	//当前索引(height数组)、是否为正面(用于交换位图)

 

<2>WndProc中的实现细节:

case WM_CREATE:
	//加载位图
	hInstance = ((LPCREATESTRUCT)lParam)->hInstance;

	hBmp[0] = LoadBitmap(hInstance, MAKEINTRESOURCE(IDB_BITMAP1));
	hBmp[1] = LoadBitmap(hInstance, MAKEINTRESOURCE(IDB_BITMAP2));

	GetObject(hBmp[0], sizeof(BITMAP), &bmp);

	sBmp.cx	= bmp.bmWidth;
	sBmp.cy	= bmp.bmHeight;

	//设置计时器
	SetTimer(hwnd, ID_TIMER, 120, NULL);
  	return 0;

 

case WM_SIZE:
	//获取客户区大小
	sClient.cx	= LOWORD(lParam);
	sClient.cy	= HIWORD(lParam);

	//修改位图当前位置坐标
	ptBmp.x		= (sClient.cx - sBmp.cx) / 2;
	ptBmp.y		= (sClient.cy - sBmp.cy) / 2;
	return 0;

 

	case WM_PAINT:
		//按照一定比例缩放位图
		hdc = BeginPaint(hwnd, &ps);

		hdcMem = CreateCompatibleDC(hdc);
		SelectObject(hdcMem, hBmp[isFirst]);

		SetStretchBltMode(hdc, COLORONCOLOR);
		StretchBlt(hdc, ptBmp.x, ptBmp.y, sBmp.cx, sBmp.cy, hdcMem, 0, 0, 200, 200, SRCCOPY);

		DeleteDC(hdcMem);
		EndPaint(hwnd, &ps);
		return 0;

 

	case WM_TIMER:
		//修改当前显示的位图高度
		sBmp.cy		= height[curIndex];

		//如果位图高度变为最小(也就是几乎看不太清的程序),就交换位图
		if(sBmp.cy == height[3])
		{
			isFirst = !(isFirst & 1);
		}

		//如果位图高度之前是原始大小,那么应该停顿一会儿,这里停顿当前线程1秒
		else if(sBmp.cy == height[0])
		{
			Sleep(1000);
		}

		//修改位图显示位置,保证居中显示
		ptBmp.y		= (sClient.cy - sBmp.cy) / 2;

		//索引下一个高度(height)
		curIndex = (curIndex + 1) % NUM;

		//重绘
		InvalidateRect(hwnd, NULL, TRUE);
		return 0;

 

 

点击下载源代码以及相关资源

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/129150.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mse pytorch_torch和pytorch

    mse pytorch_torch和pytorch在pytorch中,经常使用nn.MSELoss作为损失函数,例如loss=nn.MSELoss()input=torch.randn(3,5,requires_grad=True)target=torch.randn(3,5)error=loss(input,target)error.backward()这个地方有一个巨坑,就是一定要小心input和target的位置,说的更具…

    2022年9月17日
    0
  • k8s(十)基本存储[通俗易懂]

    k8s(十)基本存储[通俗易懂]文章目录概述EmptyDirHostPathNFSk8s的数据存储概述在前面已经提到,容器的生命周期可能很短,会被频繁的创建和销毁。那么容器在销毁的时候,保存在容器中的数据也会被清除。这种结果对用户来说,在某些情况下是不乐意看到的。为了持久化保存容器中的数据,kubernetes引入了Volume的概念。Volume是Pod中能够被多个容器访问的共享目录,它被定义在Pod上,然后被一个Pod里面的多个容器挂载到具体的文件目录下,kubernetes通过Volume实现同一个Pod中不同容器之间的数据

    2022年8月9日
    0
  • delphi xe5 安装 fastreport5「建议收藏」

    delphi xe5 安装 fastreport5「建议收藏」1、卸载fastreport42、删除fastreport4的librarypath3、安装fr5:打开recompile.exe,1、选择delphi版本 4、recompileallpackages ->compile,之后在fr5安装文件路径下会多出一个libD19文件夹4、添加fastreport5的librarypath为上一步的libD19文件夹另

    2022年7月18日
    17
  • 【Linux编程】存储映射I/O

    【Linux编程】存储映射I/O

    2022年1月20日
    56
  • Modbus 通信协议详解

    Modbus 通信协议详解一、Modbus协议简介Modbus协议是应用于电子控制器上的一种通用语言。通过此协议,控制器相互之间、控制器经由网络(例如以太网)和其它设备之间可以通信。它已经成为一通用工业标准。有了它,不同

    2022年7月4日
    17
  • treeTable v 1.4.2

    treeTable v 1.4.2treeTablev1.4.2简介treeTable是跨浏览器、性能很高的jquery的树表组件,它使用非常简单,只需要引用jquery库和一个js文件,接口也很简单。优点兼容主流浏览器:支持IE6和IE6+,Firefox,chrome,Opera,Safari接口简洁:在普通表格的基础上增加父子关系的自定义标签就可以组件性能高:内部实现了只绑

    2022年6月11日
    27

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号