本文整理汇总了C#中Point.Offset方法的典型用法代码示例。如果您正苦于以下问题:C# Point.Offset方法的具体用法?C# Point.Offset怎么用?C# Point.Offset使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Point
的用法示例。
在下文中一共展示了Point.Offset方法的12个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Right
public static Point Right(Point p, MirDirection d)
{
switch (d)
{
case MirDirection.Up:
p.Offset(1, 0);
break;
case MirDirection.UpRight:
p.Offset(1, 1);
break;
case MirDirection.Right:
p.Offset(0, 1);
break;
case MirDirection.DownRight:
p.Offset(-1, 1);
break;
case MirDirection.Down:
p.Offset(-1, 0);
break;
case MirDirection.DownLeft:
p.Offset(-1,-1);
break;
case MirDirection.Left:
p.Offset(0, -1);
break;
case MirDirection.UpLeft:
p.Offset(1, -1);
break;
}
return p;
}
示例2: UpdateMousePosition
void UpdateMousePosition()
{
mouse_current = System.Windows.Forms.Cursor.Position;
if (FreeMouse)
{
//System.Windows.Forms.Cursor.Hide();
mouse_current.Offset(-X, -Y);
mouse_current.Offset(0, -20);
//System.Windows.Forms.Cursor.Show();
}
if (!Focused)
{
return;
}
mouseleftclick = (!wasmouseleft) && Mouse[OpenTK.Input.MouseButton.Left];
mouserightclick = (!wasmouseright) && Mouse[OpenTK.Input.MouseButton.Right];
mouseleftdeclick = wasmouseleft && (!Mouse[OpenTK.Input.MouseButton.Left]);
mouserightdeclick = wasmouseright && (!Mouse[OpenTK.Input.MouseButton.Right]);
wasmouseleft = Mouse[OpenTK.Input.MouseButton.Left];
wasmouseright = Mouse[OpenTK.Input.MouseButton.Right];
if (freemousejustdisabled)
{
mouse_previous = mouse_current;
freemousejustdisabled = false;
}
if (!FreeMouse)
{
int centerx = Bounds.Left + (Bounds.Width / 2);
int centery = Bounds.Top + (Bounds.Height / 2);
mouse_delta = new Point(mouse_current.X - mouse_previous.X,
mouse_current.Y - mouse_previous.Y);
mouse_previous = mouse_current;
if ((Math.Abs(System.Windows.Forms.Cursor.Position.X - centerx) > 100)
|| (Math.Abs(System.Windows.Forms.Cursor.Position.Y - centery) > 100))
{
System.Windows.Forms.Cursor.Position =
new Point(centerx, centery);
mouse_previous = new Point(centerx, centery);
}
}
}
示例3: PointMove
public static Point PointMove(Point p, MirDirection d, int i)
{
switch (d)
{
case MirDirection.Up:
p.Offset(0, -i);
break;
case MirDirection.UpRight:
p.Offset(i, -i);
break;
case MirDirection.Right:
p.Offset(i, 0);
break;
case MirDirection.DownRight:
p.Offset(i, i);
break;
case MirDirection.Down:
p.Offset(0, i);
break;
case MirDirection.DownLeft:
p.Offset(-i, i);
break;
case MirDirection.Left:
p.Offset(-i, 0);
break;
case MirDirection.UpLeft:
p.Offset(-i, -i);
break;
}
return p;
}
示例4: WndProc
protected override void WndProc(ref Message m)
{
switch (m.Msg)
{
case WM_LButtonDown:
if (GetValueRec().IsVisible(new Point(m.LParam.ToInt32())))
{
dragin = true;
lpoint = m.LParam.ToInt32();
Point tp = new Point(lpoint);
tp.Offset(-3, -3);
europeanswallow = new Rectangle(tp, new Size(6, 6));
ltime = DateTime.Now.Ticks;
Cursor.Current = Cursors.Hand;
cans = true;
}
break;
case WM_MouseMove:
if (dragin)
{
Point p = new Point(m.LParam.ToInt32());
if (cans)
{
if (europeanswallow.Contains(p))
{
double f = DateTime.Now.Subtract(new DateTime(ltime)).TotalSeconds;
if (f >= 1.5)
cans = false;
else if (f >= 0.5)
{
dragin = false;
Cursor.Current = Cursors.SizeAll;
break;
}
}
else
cans = false;
}
float v = (float)(((AnalogMeter.PointToAngle(p)) / 180f) * (1023));
vm.Value = Math.Max(0, Math.Min(1023, v));
Cursor.Current = Cursors.Hand;
return;
}
else if (GetValueRec().IsVisible(new Point(m.LParam.ToInt32())))
{
inadorn = true;
Cursor.Current = Cursors.Hand;
}
else
inadorn = false;
break;
case WM_LButtonUp:
if (dragin)
dragin = false;
break;
}
base.WndProc(ref m);
}
示例5: OffsetTest
public void OffsetTest(int x, int y)
{
Point p1 = new Point(x, y);
Point p2 = new Point(y, x);
p1.Offset(p2);
Assert.Equal(p2.X + p2.Y, p1.X);
Assert.Equal(p1.X, p1.Y);
p2.Offset(x, y);
Assert.Equal(p1, p2);
}
示例6: Move
private void Move(Point p)
{
p = _originalForm.PointToScreen(p);
var activeScr = Screen.FromPoint(p); // get the screen from the point !!
if (!activeScr.WorkingArea.Contains(p))
{
p.X = NormalizeInside(p.X, activeScr.WorkingArea.Left, activeScr.WorkingArea.Right);
p.Y = NormalizeInside(p.Y, activeScr.WorkingArea.Top, activeScr.WorkingArea.Bottom);
}
p.Offset(-_offsetPoint.X, -_offsetPoint.Y);
// p is the exact location of the frame - so we can play with it
// to detect the new position acording to different bounds
_formRect.Location = p; // this is the new positon of the form
_formOffsetPoint.X = _stickGap + 1; // (more than) maximum gaps
_formOffsetPoint.Y = _stickGap + 1;
if (StickToScreen)
Move_Stick(activeScr.WorkingArea, false);
// Now try to snap to other windows
if (StickToOther)
{
foreach (Form sw in GlobalStickyWindows)
{
if (sw != _originalForm)
Move_Stick(sw.Bounds, true);
}
}
if (_formOffsetPoint.X == _stickGap + 1)
_formOffsetPoint.X = 0;
if (_formOffsetPoint.Y == _stickGap + 1)
_formOffsetPoint.Y = 0;
_formRect.Offset(_formOffsetPoint);
_originalForm.Bounds = _formRect;
}
示例7: OnNCLButtonDown
/// <summary>
/// Checks where the click was in the NC area and starts move or resize operation
/// </summary>
/// <param name="iHitTest"></param>
/// <param name="point"></param>
/// <returns></returns>
private bool OnNCLButtonDown(int iHitTest, Point point)
{
_offsetPoint = point;
switch (iHitTest)
{
case UnsafeNativeMethods.HT.HTCAPTION:
{
// request for move
if (StickOnMove)
{
var pointInApp = _originalForm.PointToClient(Cursor.Position);
_offsetPoint.Offset(pointInApp.X, pointInApp.Y);
StartMove();
return true;
}
return false; // leave default processing
}
// requests for resize
case UnsafeNativeMethods.HT.HTTOPLEFT:
return StartResize(ResizeDir.Top | ResizeDir.Left);
case UnsafeNativeMethods.HT.HTTOP:
return StartResize(ResizeDir.Top);
case UnsafeNativeMethods.HT.HTTOPRIGHT:
return StartResize(ResizeDir.Top | ResizeDir.Right);
case UnsafeNativeMethods.HT.HTRIGHT:
return StartResize(ResizeDir.Right);
case UnsafeNativeMethods.HT.HTBOTTOMRIGHT:
return StartResize(ResizeDir.Bottom | ResizeDir.Right);
case UnsafeNativeMethods.HT.HTBOTTOM:
return StartResize(ResizeDir.Bottom);
case UnsafeNativeMethods.HT.HTBOTTOMLEFT:
return StartResize(ResizeDir.Bottom | ResizeDir.Left);
case UnsafeNativeMethods.HT.HTLEFT:
return StartResize(ResizeDir.Left);
}
return false;
}
示例8: SetupHexagonalGrid
void SetupHexagonalGrid()
{
// Make cell regions: we assume cells have only 1 region but that can change in the future
int l = _numCells;
int qx, qy;
int q = (int)(Math.Sqrt (l));
q = q * 12 / 13;
if (q<1) q= 1;
qx=qy=q;
int qx2 = qx * 4 / 3;
double stepX = (transform.localScale.y / transform.localScale.x) / qx;
double stepY = (transform.localScale.x / transform.localScale.y) / qy;
double halfStepX = stepX*0.5;
double halfStepY = stepY*0.5;
Segment [,,] sides = new Segment[qx2,qy,6]; // 0 = left-up, 1 = top, 2 = right-up, 3 = right-down, 4 = down, 5 = left-down
int c = -1;
int subdivisions = goodGridCurvature > 0 ? 3: 1;
for (int j=0;j<qy;j++) {
for (int k=0;k<qx2;k++) {
Point center = new Point((double)k/qx-0.5+halfStepX,(double)j/qy-0.5+halfStepY);
center.x -= k * halfStepX/2;
Cell cell = new Cell( (++c).ToString(), new Vector2((float)center.x, (float)center.y));
double offsetY = (k % 2==0) ? 0: -halfStepY;
Segment leftUp = (k>0 && offsetY<0) ? sides[k-1, j, 3]: new Segment(center.Offset(-halfStepX, offsetY), center.Offset(-halfStepX/2, halfStepY + offsetY), k==0 || (j==qy-1 && offsetY==0));
sides[k, j, 0] = leftUp;
Segment top = new Segment(center.Offset(-halfStepX/2, halfStepY + offsetY), center.Offset(halfStepX/2, halfStepY + offsetY), j==qy-1);
sides[k, j, 1] = top;
Segment rightUp = new Segment(center.Offset(halfStepX/2, halfStepY + offsetY), center.Offset(halfStepX, offsetY), k==qx2-1 || (j==qy-1 && offsetY==0));
sides[k, j, 2] = rightUp;
Segment rightDown = (j > 0 && k<qx2-1 && offsetY<0) ? sides[k+1,j-1,0]: new Segment(center.Offset(halfStepX, offsetY), center.Offset(halfStepX/2, -halfStepY + offsetY), (j==0 && offsetY<0)|| k==qx2-1);
sides[k, j, 3] = rightDown;
Segment bottom = j>0 ? sides[k, j-1, 1] : new Segment(center.Offset(halfStepX/2, -halfStepY + offsetY), center.Offset(-halfStepX/2, -halfStepY +offsetY), true);
sides[k, j, 4] = bottom;
Segment leftDown;
if (offsetY<0 && j>0) {
leftDown = sides[k-1, j-1, 2];
} else if (offsetY==0 && k>0) {
leftDown = sides[k-1, j, 2];
} else {
leftDown = new Segment(center.Offset(-halfStepX/2, -halfStepY+offsetY), center.Offset(-halfStepX, offsetY), true);
}
sides[k, j, 5] = leftDown;
if (j==0) {
// leftDown.CropBottom();
// bottom.CropBottom();
// rightDown.CropBottom();
}
if (k==qx2-1) {
top.CropRight();
rightUp.CropRight();
rightDown.CropRight();
bottom.CropRight();
}
Region cr = new Region (cell);
if (subdivisions>1) {
if (!top.deleted) cr.segments.AddRange (top.Subdivide(subdivisions, _gridCurvature));
if (!rightUp.deleted) cr.segments.AddRange (rightUp.Subdivide(subdivisions, _gridCurvature));
if (!rightDown.deleted) cr.segments.AddRange (rightDown.Subdivide(subdivisions, _gridCurvature));
if (!bottom.deleted) cr.segments.AddRange (bottom.Subdivide(subdivisions, _gridCurvature));
if (!leftDown.deleted) cr.segments.AddRange (leftDown.Subdivide(subdivisions, _gridCurvature));
if (!leftUp.deleted) cr.segments.AddRange (leftUp.Subdivide(subdivisions, _gridCurvature));
} else {
if (!top.deleted) cr.segments.Add (top);
if (!rightUp.deleted) cr.segments.Add (rightUp);
if (!rightDown.deleted) cr.segments.Add (rightDown);
if (!bottom.deleted) cr.segments.Add (bottom);
if (!leftDown.deleted) cr.segments.Add (leftDown);
if (!leftUp.deleted) cr.segments.Add (leftUp);
}
Connector connector = new Connector();
connector.AddRange(cr.segments);
cr.polygon = connector.ToPolygon(); // FromLargestLineStrip();
if (cr.polygon!=null) {
cell.region = cr;
cells.Add (cell);
}
}
}
}
示例9: SetupBoxGrid
void SetupBoxGrid(bool strictQuads)
{
// Make cell regions: we assume cells have only 1 region but that can change in the future
int l = _numCells;
int qx, qy;
int q = (int)(Math.Sqrt (l));
if (strictQuads) {
qx=qy=q;
} else {
qx=l;
qy=1;
if (q<1) q=1;
if ( (int)(q*q) != l) { // not squared
if (!GetTwoFactors(l, out qx, out qy)) {
// if number > 10 and it's prime, reduce by one so we can avoid ugly accordian grids
if (l>10) GetTwoFactors(l-1, out qx, out qy);
}
} else {
qx = qy = q;
}
}
double stepX = (transform.localScale.y / transform.localScale.x) / qx;
double stepY = (transform.localScale.x / transform.localScale.y) / qy;
double halfStepX = stepX*0.5;
double halfStepY = stepY*0.5;
Segment [,,] sides = new Segment[qx,qy,4]; // 0 = left, 1 = top, 2 = right, 3 = bottom
int c = -1;
int subdivisions = goodGridCurvature > 0 ? 3: 1;
for (int k=0;k<qx;k++) {
for (int j=0;j<qy;j++) {
Point center = new Point((double)k/qx-0.5+halfStepX,(double)j/qy-0.5+halfStepY);
Cell cell = new Cell( (++c).ToString(), new Vector2((float)center.x, (float)center.y));
Segment left = k>0 ? sides[k-1, j, 2] : new Segment(center.Offset(-halfStepX, -halfStepY), center.Offset(-halfStepX, halfStepY), true);
sides[k, j, 0] = left;
Segment top = new Segment(center.Offset(-halfStepX, halfStepY), center.Offset(halfStepX, halfStepY), j==qy-1);
sides[k, j, 1] = top;
Segment right = new Segment(center.Offset(halfStepX, halfStepY), center.Offset(halfStepX, -halfStepY), k==qx-1);
sides[k, j, 2] = right;
Segment bottom = j>0 ? sides[k, j-1, 1] : new Segment(center.Offset(halfStepX, -halfStepY), center.Offset(-halfStepX, -halfStepY), true);
sides[k, j, 3] = bottom;
Region cr = new Region (cell);
if (subdivisions>1) {
cr.segments.AddRange (top.Subdivide(subdivisions, _gridCurvature));
cr.segments.AddRange (right.Subdivide(subdivisions, _gridCurvature));
cr.segments.AddRange (bottom.Subdivide(subdivisions, _gridCurvature));
cr.segments.AddRange (left.Subdivide(subdivisions, _gridCurvature));
} else {
cr.segments.Add (top);
cr.segments.Add (right);
cr.segments.Add (bottom);
cr.segments.Add (left);
}
Connector connector = new Connector();
connector.AddRange(cr.segments);
cr.polygon = connector.ToPolygon(); // FromLargestLineStrip();
if (cr.polygon!=null) {
cell.region = cr;
cells.Add (cell);
}
}
}
}
示例10: HitImageTestAt
private bool HitImageTestAt(Point p, ListViewItem item)
{
Rectangle rcItem = item.GetBounds(ItemBoundsPortion.Entire);
GraphicsUnit units = GraphicsUnit.Point;
if (item.ImageList != null)
{
Image img = item.ImageList.Images[0];
RectangleF rcImageF = img.GetBounds(ref units);
Rectangle rcImage = Rectangle.Round(rcImageF);
rcImage.Width += item.IndentCount + item.Position.X;
p.Offset(rcItem.Left, -rcItem.Top);
if (rcImage.Contains(p))
{
return true;
}
else
{
return false;
}
}
return false;
}
示例11: OffsetPolar
public static Point OffsetPolar(Point o, double th, double dist)
{
int dx = MathEx.Round(dist*Math.Cos(th));
int dy = MathEx.Round(dist*Math.Sin(th));
o.Offset(dx,dy);
return o;
}
示例12: OnLayout
protected override void OnLayout(LayoutEventArgs levent)
{
// set the size and location for close and auto-hide buttons
Rectangle rectCaption = ClientRectangle;
int buttonWidth = ImageCloseEnabled.Width;
int buttonHeight = ImageCloseEnabled.Height;
int height = rectCaption.Height - ButtonGapTop - ButtonGapBottom;
if (buttonHeight < height)
{
buttonWidth = buttonWidth * (height / buttonHeight);
buttonHeight = height;
}
m_buttonClose.SuspendLayout();
m_buttonAutoHide.SuspendLayout();
m_buttonOptions.SuspendLayout();
Size buttonSize = new Size(buttonWidth, buttonHeight);
m_buttonAutoHide.Size = buttonSize;
m_buttonClose.Size = buttonSize;
m_buttonOptions.Size = buttonSize;
int x = rectCaption.X + rectCaption.Width - 1 - ButtonGapRight - m_buttonClose.Width;
int y = rectCaption.Y + ButtonGapTop;
Point point = new Point(x, y);
m_buttonClose.Location = point;
point.Offset(- (m_buttonAutoHide.Width + ButtonGapBetween), 0);
m_buttonAutoHide.Location = point;
point.Offset(- (m_buttonOptions.Width + ButtonGapBetween), 0);
m_buttonOptions.Location = point;
m_buttonClose.ResumeLayout();
m_buttonAutoHide.ResumeLayout();
m_buttonOptions.ResumeLayout();
base.OnLayout(levent);
}