针对【Cocoa(mac)Application开发系列之三】自定义NSView并绘制一些常见的图形及字符串;这个问题,本篇文章进行了详细的解答,同时本文还将给你拓展Ajax:ANewApproach
针对【Cocoa(mac) Application 开发系列之三】自定义NSView并绘制一些常见的图形及字符串;这个问题,本篇文章进行了详细的解答,同时本文还将给你拓展Ajax: A New Approach to Web Applications、android – ApplicationStatus类E / SysUtils:ApplicationStat中的ApplicationContext为null、Application Session Cookie ViewState Cache Hidden 区别、Asp.net中Application Session Cookie ViewState Cache等相关知识,希望可以帮助到你。
本文目录一览:- 【Cocoa(mac) Application 开发系列之三】自定义NSView并绘制一些常见的图形及字符串;
- Ajax: A New Approach to Web Applications
- android – ApplicationStatus类E / SysUtils:ApplicationStat中的ApplicationContext为null
- Application Session Cookie ViewState Cache Hidden 区别
- Asp.net中Application Session Cookie ViewState Cache
【Cocoa(mac) Application 开发系列之三】自定义NSView并绘制一些常见的图形及字符串;
http://blog.csdn.net/xiaominghimi/article/details/7642624
不多说,比较简单,直接给出源码,大家作为参考吧。
对于Cocoa application 话说回来比较easy,如果之前你接触过iOS 的IB的话 ,基本上没什么可说的,上手很快;
因此对于Cocoa Application 不会太快的更新,接着Himi将对之前做的动编彻底的更新一版;后期有时间将继续更新此系列;
言归正传,对于自定义NSView上一篇已经介绍了,而且本篇主要继续深入NSView的drawRect进行继续研究,示例代码如下,比较容易理解,而且都已备注的很清楚;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
//
// HView.m
//
// Created by Himi on 12-6-7.
// copyright (c) 2012年 Himi. All rights reserved.
//
#import "HView.h"
@implementation HView
- (id)initWithFrame:(NSRect)frame
{
self = [super initWithFrame:frame];
if
(self) {
// Initialization code here.
}
return
self;
}
- (
void
)drawRect:(NSRect)dirtyRect
{
//-----------获取整个MyView尺寸------------
NSRect screen = [self bounds];
int
SW = screen.size.width;
SH = screen.size.height;
//-----------设置整个MyView的颜色------------
[[NSColor grayColor] set];
//-----------填充整个MyView---------------
NSRectFill(screen);
//-----------绘制字符串---------------
Nsstring * strH= @
"基础绘制 --By Himi"
;
//--绘制不带属性字符串
[strH drawAtPoint:NSMakePoint(SH*0.5,SH-30) withAttributes:NULL];
|
//--绘制带属性字符串
NSMutableDictionary *md = [NSMutableDictionary dictionary];
[md setobject:[NSFont fontWithName:@
"Times"
size:20] forKey:NSFontAttributeName];
//--------绘制矩形----
NSRect rect1 = NSMakeRect(SH*0.5,SH-100,30,20);
NSRect rect2 = NSMakeRect(SH*0.5,SH-130,20);
//填充矩形
[NSBezierPath fillRect:rect1];
//绘制矩形
[NSBezierPath strokeRect:rect2];
//--------绘制线条(十字线)----
[[NSColor greenColor] set];
NSPoint bm =NSMakePoint(SW*0.5,0);
NSPoint top =NSMakePoint(SW*0.5,SH);
NSPoint lf =NSMakePoint(0,SH*0.5);
NSPoint rt =NSMakePoint(SW,SH*0.5);
[NSBezierPath strokeLineFromPoint:bm toPoint:top];
[NSBezierPath strokeLineFromPoint:lf toPoint:rt];
//-------绘制椭圆
[[NSColor redColor] set];
[[NSBezierPath bezierPathWithovalInRect:screen] stroke];
[self setNeedsdisplay:YES];
// 强制绘画
//【备注】
// CGContextRef ref = [[NSGraphicsContext currentContext] graphicsPort];// 获取画布
// CGContextFlush(ref);//刷新画布
}
-(
) mouseDragged:(NSEvent *)theEvent{
NSPoint mp = [self convertPoint:[theEvent locationInWindow] fromView:nil];
// 鼠标新坐标
NSLog(@
"mouseDragged~%f,%f"
,mp.x,mp.y);
}
) mouseUp:(NSEvent *)theEvent{
"mouseUp"
);
}
) mouseDown:(NSEvent *)theEvent{
"mouseDown"
);
}
@end
|
注意的是:备注 这两行代码是直接通过获取画布,更新画布进行绘制,其中绘制代码省略,比较容易,这里起个头,推荐使用此种方式绘制;对于做游戏的我们,对于画布刷新画布我想是再熟悉不过了!
运行截图:
Ajax: A New Approach to Web Applications
总结
以上是小编为你收集整理的Ajax: A New Approach to Web Applications全部内容。
如果觉得小编网站内容还不错,欢迎将小编网站推荐给好友。
android – ApplicationStatus类E / SysUtils:ApplicationStat中的ApplicationContext为null
E / SysUtils:ApplicationStat中的ApplicationContext为null
有谁知道ApplicationStatus类?我没有在我的项目中
它发生在我在openGL中快速渲染纹理时
解决方法
我的问题是在打开新意图时直接传递额外的变量,如下所示.
>调用代码:
intent.putExtra("markerdata: ",assetVO);
>接收代码:
markerdata = (HashMap<String,Object>) getIntent().getSerializableExtra("markerdata");
2天前升级到Android Studio 1.3后,我总是变为空.
所以我的工作是将传递的信息捆绑在一起:
>调用代码:
Bundle b = new Bundle(); b.putSerializable("markerdata",assetVO); intent.putExtras(b);
>接收代码:
Bundle extras = getIntent().getExtras(); markerdata = (HashMap<String,Object>) extras.getSerializable("markerdata");
现在它的工作原理.希望它可以帮助别人.
Application Session Cookie ViewState Cache Hidden 区别
ASP.NET中,有多种保存信息的对象,如:Application,Session,Cookie,ViewState、Cache等,它们有什么区别?应用环境是什么?
为了更清楚的了解,我们总结出每一种对象应用的具体环境,如下表所示:
Application
1、Application用来保存所有用户共用的信息;
2、在Asp时代,如果要保存的数据在应用程序生存期内不会或者很少发生改变,那么使用Application是理想的选择。但是在Asp.net开发环境中我们把类似的配置数据放在Web.config中;
3、如果要使用Application要注意的是所有的写操作都要在Application_OnStart事件中完成(global.Asax),尽管可以使用Application.Lock()避免了冲突,但是它串行化了对Application的请求,会产生严重的性能瓶颈;
4、不要使用Application保存大数据量信息;
5、代码:
Application["UserID"] = "test"; //写
string UserName = Application["UserID"].ToString(); //读
Session
1、Session用来保存每一个用户的专有信息;
2、Session的生存期是用户持续请求时间加上一段时间(一般是20分钟左右);
3、Session信息是保存在Web服务器内存中的,保存数据量可大可小;
4、Session超时或者被关闭将自动释放数据信息;
5、由于用户停止使用应用程序之后它仍在内存中存留一段时间,因此这种方法效率较低;
6、代码:
Session["UserID"] = "test"; //写
string UserName = Session["UserID"].ToString(); //读
Cookie
1、Cookie用来保存客户浏览器请求服务器页面的请求信息;
2、我们可以存放非敏感的用户信息,保存时间可以根据需要设置;
3、如果没有设置Cookie失效日期,它的生命周期保存到关闭浏览器为止;
4、Cookie对象的Expires属性设置为MinValue表示永不过期;
5、Cookie存储的数据量受限制,大多数的浏览器为4K因此不要存放大数据;
6、由于并非所有的浏览器都支持Cookie,数据将以明文的形式保存在客户端;
7、代码:
Resopnse.Cookies["UserID"] = "test"; //写
string UserName = Resopnse.Cookies["UserID"].ToString(); //读
ViewState
1、ViewState用来保存用户的状态信息,有效期等于页面的生命周期;
2、可以保存大量数据但是要慎用,因为会影响程序性能;
3、所有的Web服务器控件都是用ViewState在页面PostBack期间保存状态;
4、不需要则关闭 @page 里面设置EnableViewState=false;
5、代码:
ViewState["ID"] = "test"; //写
string ID = ViewState["ID"].ToString(); //读
Cache
1、Cache用于在Http请求期间保存页面或者数据;
2、Cache的使用可以大大的提高整个应用程序的效率;
3、它允许将频繁访问的服务器资源存储在内存中,当用户发出相同的请求后,服务器不是再次处理而是将Cache中保存的数据直接返回给用户;
4、可以看出Cache节省的是时间(服务器处理时间);
5、Cache实例是每一个应用程序专有的,其生命周期==该应用程序周期,应用程序重启将重新创建其实例;
6、注意:如果要使用缓存的清理、到期管理、依赖项等功能必须使用Insert 或者Add方法方法添加信息;
7、代码:
Cache["ID"] = "test"; 或者 Cache.Insert("ID","test"); //写
string ID = Cache["ID"].ToString(); //读
Hidden
1、Hidden控件属于html类型的服务器控件,要使用Runat=server,始终处于隐藏状态;
2、每一次提交的时候它会和其他服务器控件一起提交到服务器端;
3、代码:
Hidden.Value = "king"; //写
string id = Hidden.Value; //读
查询字符串
1、查询字符串的方式是将要传递的值连接在URL后面;
2、一般用于页面之间传递信息;
3、由于URL的长度有一定的限制,因此不能传递太大的信息;
4、安全性不是很好。
5、代码:
Response.Redirect("List.aspx?id=123&name=abc"); //传值页面
string name = Request.QueryString["name"]; //取值页面
string id = Request.QueryString["id"];
global.Asax 文件
Application_start:
第一个访问网站的用户会触发该方法. 通常会在该方法里定义一些系统变量,如聊天室的在线总人数统计、,历史访问人数统计的初始化等等均可在这里定义.
Application_end:
网站关闭,或重启时,会触发该方法. 没有进行过多试验.
Session_start :
每个用户访问网站的第一个页面时触发;
Session_end:
使用了session.abandon(),或session超时用户退出后均可触发.
注意:
Session_end中不能使用session对象、 server.mappath()、服务器对象。 所以只能用session.contents("username") 取代session("username"),或者用Application对象或方法;
例如:
想在session_end中使用Server.MapPath("users.xml"),则应在Application_start 中定义Application("xmlPath") = Server.MapPath("users.xml"),然后在session_end中调用Application("XmlPath"),而不能直接在session_end中使用诸如:Server.MapPath("users.xml"),
Application、session执行顺序是:
1、Application_start
2、session_start
3、session_end
4、Application_end
原文链接: http://blog.csdn.net/sunboy_2050/article/details/6627108
Asp.net中Application Session Cookie ViewState Cache
Asp.net中Application Session Cookie ViewState Cache
Application
1. Application用来保存所有用户共用的信息 (网站内共享数据)
2. 在Asp时代,如果要保存的数据在应用程序生存期内不会或者很少发生改变,那么使用Application是理想的选择。但是在Asp.net开发环境中我们把类似的配置数据放在Web.config中。
3. 如果要使用Application 要注意的是所有的写操作都要在Application_OnStart事件中完成(global.Asax),尽管可以使用Application.Lock()避免了冲突,但是它串行化了对Application的请求,会产生严重的性能瓶颈。
4. 不要使用Application保存大数据量信息
5. 代码:Application[“UserID”]="test”;
String UserName=Application[“UserID”].ToString();
Session
1. Session用来保存每一个用户的专有信息
2. Session的生存期是用户持续请求时间加上一段时间(一般是20分钟左右)
3. Session信息是保存在Web服务器内存中的,保存数据量可大可小
4. Session超时或者被关闭将自动释放数据信息
5. 由于用户停止使用应用程序之后它仍在内存中存留一段时间,因此这种方法效率较低
6. 代码:Session[“UserID”]="test”;
String UserName=Session[“UserID”].ToString();
Cookie
1. Cookie用来保存客户浏览器请求服务器页面的请求信息
2. 我们可以存放非敏感的用户信息,保存时间可以根据需要设置
3. 如果没有设置Cookie失效日期,它的生命周期保存到关闭浏览器为止
4. Cookie对象的Expires属性设置为MinValue表示永不过期
5. Cookie存储的数据量受限制,大多数的浏览器为4K因此不要存放大数据
6. 由于并非所有的浏览器都支持Cookie,数据将以明文的形式保存在客户端
7. 代码:Resopnse.Cookies[“UserID”]=”test”;
String UserName= Resopnse.Cookies [“UserID”].ToString();
ViewState
1. ViewState用来保存用户的状态信息,有效期等于页面的生命周期
2. 可以保存大量数据但是要慎用,因为会影响程序性能
3. 所有的Web服务器控件都是用ViewState在页面PostBack期间保存状态
4. 不需要则关闭 @page 里面设置EnableViewState=false
5. 代码:ViewState[‘”ID”]="yiner”;
String ID =ViewState[“ID”].ToString();
Cache
1. Cache用于在Http请求期间保存页面或者数据
2. Cache的使用可以大大的提高整个应用程序的效率
3. 它允许将频繁访问的服务器资源存储在内存中,当用户发出相同的请求后,服务器不是再次处理而是将Cache中保存的数据直接返回给用户
4. 可以看出Cache节省的是时间—服务器处理时间
5. Cache实例是每一个应用程序专有的,其生命周期==该应用程序周期,应用程序重启将重新创建其实例
6. 注意:如果要使用缓存的清理、到期管理、依赖项等功能必须使用Insert 或者Add方法方法添加信息
7. 代码:Cache[‘”ID”]="yiner”;或者Cache.Insert(“ID”,"test”);
String ID =Cache[“ID”].ToString();
Hidden
1. Hidden控件属于Html类型的服务器控件,始终处于隐藏状态
2. 每一次提交的时候它会和其他服务器控件一起提交到服务器端
3. 代码如下:Hidden.Value=”king”;
string id=Hidden.Value; 要使用Runat=server
ASP.NET Application,Session,Cookie和ViewState等对象用法和区别
在ASP.NET中,有很多种保存信息的内置对象,如:Application,Session,Cookie,ViewState和Cache等。下面分别介绍它们的用法和区别。
1.Application对象
Application用于保存所有用户的公共的数据信息,如果使用Application对象,一个需要考虑的问题是任何写操作都要在Application_OnStart事件(global.asax)中完成.尽管使用Application.Lock和Applicaiton.Unlock方法来避免写操作的同步,但是它串行化了对Application对象的请求,当网站访问量大的时候会产生严重的性能瓶颈.因此最好不要用此对象保存大的数据集合. 下面我们做个在线用户统计的例子来说明这个问题:
(以文件的形式存放网站总访问量)
Global.asax类
using System;
using System.Collections;
using System.ComponentModel;
using System.Web;
using System.Web.SessionState;
using System.IO;
/// Global 的摘要说明。
public
class Global : System.Web.HttpApplication
{
///
必需的设计器变量。
private System.ComponentModel.IContainer components = null;
private FileStream fileStream;
private StreamReader reader;//读字符流
private StreamWriter writer;//写字符流
public Global()
{
InitializeComponent();
}
protected
void Application_Start(Object sender, EventArgs e)
{
Application["CurrentGuests"]=0;//初始花为0;
fileStream = File.Open(Server.MapPath("counts.text"),FileMode.OpenorCreate);//文件不存在,创建文件
reader = new StreamReader(fileStream);//要读取的完整路径
Application["AllGuests"] = Convert.ToInt32(reader.ReadLine()); //从当前流中读取一行字符并将数据作为字符串返回
reader.Close();//关闭流
}
protected
void Session_Start(Object sender, EventArgs e)//当用户访问网站时,在线用户+1,总访问数+1
{
Application.Lock();//同步,避免同时写入
Application["CurrentGuests"] =(int)Application["CurrentGuests"]+ 1;//总在线用户数
Application["AllGuests"] =(int)Application["AllGuests"]+ 1;//访问网站的总用户数
fileStream = new FileStream(Server.MapPath("counts.text"),FileMode.OpenorCreate,FileAccess.ReadWrite);//
writer = new StreamWriter(fileStream);//实现一个写入流,使其以一种特定的编码向流中写入字符
writer.WriteLine(Application["AllGuests"].ToString());//把访问网站的总用户数再次写入到文件
writer.Close();//关闭写入流
Application.UnLock();//同步结束
}
protected
void Session_End(Object sender, EventArgs e)//当前用户退出网站时,在线用户数量-1,
{
Application.Lock();
Application["CurrentGuests"] =(int)Application["CurrentGuests"] - 1;//总在线用户数量-1
Application.UnLock();
}
(2) WebForm1.aspx
private
void Page_Load(object sender, System.EventArgs e)
{
this.Label1.Text = "正在访问站点的用户数:" + Application["CurrentGuests"].ToString();
this.Label2.Text ="访问过站点的总用户数:" + Application["AllGuests"].ToString();
}
2.Session对象
Session用于保存每个用户的专用信息.每个客户端用户访问时,服务器都为每个用户分配一个唯一的会话ID(Session ID) . 她的生存期是用户持续请求时间再加上一段时间(一般是20分钟左右).Session中的信息保存在Web服务器内容中,保存的数据量可大可小.当Session超时或被关闭时将自动释放保存的数据信息.由于用户停止使用应用程序后它仍然在内存中保持一段时间,因此使用Session对象使保存用户数据的方法效率很低.对于小量的数据,使用Session对象保存还是一个不错的选择.使用Session对象保存信息的代码如下:
//存放信息
Session["key"]="value"
//读取数据
string UserName=Session["key"].ToString();
3.Cookie对象
Cookie用于保存客户浏览器请求服务器页面的请求信息,程序员也可以用它存放非敏感性的用户信息,信息保存的时间可以根据需要设置.如果没有设置Cookie失效日期,它们仅保存到关闭浏览器程序为止.如果将Cookie对象的Expires属性设置为Minvalue,则表示Cookie永远不会过期.Cookie存储的数据量很受限制,大多数浏览器支持最大容量为4K,因此不要用来保存数据集及其他大量数据.由于并非所有的浏览器都支持Cookie,并且数据信息是以明文文本的形式保存在客户端的计算机中,因此最好不要保存敏感的,未加密的数据,否则会影响网站的安全性.使用Cookie对象保存的代码如下:
//存放信息
Response.Cookies["key"].Value="value";
//读取信息
string UserID=Response.Cookies["key"].Value;
4.ViewState对象
ViewState 常用于保存单个用户的状态信息,有效期等于页面的生存期。跟隐藏控件相似。viewstate是在本页面之内各函数间进行传值的 , 至于为什么要使用这种方法是因为在一个事件发生之后 , 页面可能会刷新 , 如果定义全局变量会被清零 , 所以要使用 viewstate. ViewState容器可以保持大量的数据,但是必须谨慎使用,因为过多使用会影响应用程序的性能。所有Web服务器控件都使用ViewState在页面回发期音保存自己的状态信息。如果某个控件不需要在回发期间保存状态信息,最好关闭该对象的ViewState,避免不必要的资源浪费。通过给@Page指令添加“EnableViewState=false”属性可以禁止整个页面的ViewState。使用ViewState对象保存信息的代码如下。
//存放信息
ViewState["key"]="value";
//读取信息
string NameID=ViewState["nameID"].ToString();
5.Cache对象
Cache对象用于在HTTP请求间保存页面或数据。该对象的使用可以极大地提高整个应用程序的效率。常用于将频繁访问的大量服务器资源存储在内存中,当用户发出相同的请求后服务器不再次处理而是将Cache中保存的信息返回给用户,节省了服务器处理请求的时间。其生存期依赖于该应用程序的生存期。当重新启动应用程序时,将重新创建其Cache对象的实例。使用Cache对象保存信息的代码如下。
//存放信息
Cache["nameID"]="0001";
//存放信息
Cache.Insert("nameID","0001"1);
//读取信息
string NameID=Cache["nameID"].ToString();
6.隐藏域
Hidden控件是属于HTML类型的服务器控件,使用此控件可以实现隐藏域的功能。其实此控件和其它服务器控件的使用没有太大区别,只是它不会在用户端的浏览器中显示,始终处于隐藏状态。但是每次页面提交的时候,此控件和其它服务器控件一同提交到服务器端,因此在服务器端可以使用Value属性获取或保存一些数据信息。使用Hidden控件保存信息的代码如下。
//存放信息
Hidden.Value="0001";
//获取信息
string NameID=Hidden.Value;
7.查询字符串
查询字符串的方式是将要传递的值连接在URL后面,然后通过Response.Redirect方法实现客户端的重定向。这种方式可以实现在两个页面之间传递信息。由于URL的长度有一定的限制,因此不能传递太大的信息,加外安全性也不是很好。
传递信息如下。
问号后面格式 key1=value1&key2=value2
Response.Redirect("List.aspx?nameID=0001&gradeID=002");
//执行上面的语句后在IE地址栏显示的URL的代码如下。
http://localhost/List.aspx?nameID=0001&grade=002
//当跳转到List.aspx后,可以通过以下代码获得所传递的信息。
string NameID.GradeID;
NameID=Request.Params["nameID"];
GradeID=Request.Params["gradeID"];
关于【Cocoa(mac) Application 开发系列之三】自定义NSView并绘制一些常见的图形及字符串;的问题我们已经讲解完毕,感谢您的阅读,如果还想了解更多关于Ajax: A New Approach to Web Applications、android – ApplicationStatus类E / SysUtils:ApplicationStat中的ApplicationContext为null、Application Session Cookie ViewState Cache Hidden 区别、Asp.net中Application Session Cookie ViewState Cache等相关内容,可以在本站寻找。
本文标签: