zoukankan      html  css  js  c++  java
  • 用SWT做圆形控件

    public static void main(String[] args) {

            final Display display = new Display();

            final Shell shell = new Shell(display, SWT.NO_TRIM);

            Region region = new Region();

            region.add(circle(20, 500, 300));

            shell.setRegion(region);

            // shell.setBackground(display.getSystemColor(SWT.COLOR_DARK_GRAY));

           shell.setBackgroundImage(new Image(shell.getDisplay(),"C://Program Files//Movie Maker//Shared//Sample2.jpg"));

            Listener l = new Listener() {

                int startX, startY;

                public void handleEvent(Event e) {

                    if (e.type == SWT.KeyDown && e.character == SWT.ESC) {

                        shell.dispose();

                    }

                    if (e.type == SWT.MouseDown && e.button == 1) {

                        startX = e.x;

                        startY = e.y;

                    }

                    if (e.type == SWT.MouseMove && (e.stateMask & SWT.BUTTON1) != 0) {

                        Point p = shell.toDisplay(e.x, e.y);

                        p.x -= startX;

                        p.y -= startY;

                        shell.setLocation(p);

                    }

                }

            };

            shell.addListener(SWT.KeyDown, l);

            shell.addListener(SWT.MouseDown, l);

            shell.addListener(SWT.MouseMove, l);

            shell.addListener(SWT.Paint, l);

            shell.open();

            while (!shell.isDisposed()) {

                if (!display.readAndDispatch())

                    display.sleep();

            }

            region.dispose();

            display.dispose();

        }

        static int[] circle(int r, int offsetX, int offsetY) {

            int[] polygon = new int[8 * r + 4];

            // x^2 + y^2 = r^2

            for (int i = 0; i < 2 * r + 1; i++) {

                int x = i - r;

                int y = (int)Math.sqrt(r*r - x*x);

                polygon[2*i] = offsetX + x;

                polygon[2*i+1] = offsetY + y;

                polygon[8*r - 2*i - 2] = offsetX + x;

                polygon[8*r - 2*i - 1] = offsetY - y;

            }

            return polygon;

        }

  • 相关阅读:
    Qt 的插件制作遇到的问题
    Qt实现原生Flow实现不了的Item错误排列效果,类似淘宝商品展示
    通过pro文件使Qt的build目录更清爽
    No rule to make target
    Qtcreator中printf()/fprintf()不显示问题处理方法
    QtCreator集成的MSVC套件有问题
    启动程序失败,路径或者权限错误
    图数据库 Nebula Graph 的数据模型和系统架构设计
    NLP(十六)轻松上手文本分类
    NLP(十五)让模型来告诉你文本中的时间
  • 原文地址:https://www.cnblogs.com/okuc/p/4111598.html
Copyright © 2011-2022 走看看