如何在 SwiftUI 中缩放路径?

如何解决如何在 SwiftUI 中缩放路径?

我在根据我的目的缩放 Path 时遇到了一些问题。我从 API 获取了一些我想在我的视图中绘制的 SVG 数据。为了简单起见,让我们说这是我从 API 中得到的:

extension UIBezierPath {
    static var rectangle: UIBezierPath {
        let path = UIBezierPath()
        path.move(to: CGPoint(x: 200,y: 100))
        path.addLine(to: CGPoint(x: 100,y: 300))
        path.addLine(to: CGPoint(x: 300,y: 300))
        path.addLine(to: CGPoint(x: 200,y: 100))
        return path
    }
}

当我在视图中显示此路径时,一切正常。

enter image description here

由于来自 API 的 SVG 坐标具有偏移量并且有时比 iPhone 的显示屏大,我需要将它们按比例缩小/放大到特定大小并将它们居中显示在我的视图中。为了做到这一点,我尝试了这种转换:

struct ScaledShapeView: Shape {
    let bezier: UIBezierPath

    func path(in rect: CGRect) -> Path {
        let bounds = bezier.bounds
        let scaleX = rect.size.width/bounds.size.width
        let scaleY = rect.size.height/bounds.size.height
        let scale = max(scaleX,scaleY)
        return Path(bezier.cgPath).applying(CGAffineTransform(scaleX: scale,y: scale))
    }
}

并在我看来使用它:

struct TestView: View {    
    var body: some View {
            ScaledShapeView(bezier: .rectangle)
                .frame(width: 100,height: 100)
    }
}

但这是我的结果:

enter image description here

我不确定到底是什么问题。我想实现形状在框架的中间。

@SwiftPunk:

当我尝试

var body: some View {
    Path(UIBezierPath.logo1.cgPath)
            .frame(width: 100,height: 100)
            .scaleEffect(CGSize(width: 0.5,height: 0.5))
}

我得到了这个结果:

enter image description here

解决方法

标准化每个 X 和 Y 位置以绘制 0 和 1 之间的点,其中 0 表示顶边或前缘,1 表示底边或后缘。

此外,我们将找到宽度和高度的最小值,以便我们可以按比例缩放 Bezier 路径,使其在增长时保持相同的形状。

    import java.awt.*;
    import java.util.Scanner;
    import javax.swing.*;
    
    public class Colors {
    
        public static final int CLI = 0,GUI = 1;
        private Color color = Color.RED;//default value
        private static final int CYCLE_TIME = 1000;
        private static final String[] colorsNames = {"Red","Green","Blue"};
    
        public Colors(int userInputBy) {
    
            if(userInputBy == CLI){
                cliInput();
            }else if (userInputBy == GUI){
                guiInput();
            }//or else use default
    
            changing();
        }
    
        private void guiInput() {
    
            //use JOptionPane to get input from user 
            JSpinner colorSpinner = new JSpinner(new SpinnerListModel(colorsNames));
            int answer = JOptionPane.showOptionDialog(null,colorSpinner,"Select color",JOptionPane.OK_CANCEL_OPTION,JOptionPane.QUESTION_MESSAGE,null,null);
            String colorName ="";
            if (answer == JOptionPane.OK_OPTION) {// user selected a color
                colorName = (String) colorSpinner.getValue();
            }
    
            colorByName(colorName);
        }
    
        private void cliInput() {
    
            Scanner scanner = new Scanner(System.in);
            System.out.println("Enter Color Choice (Red/Green/Blue)");
            String colorName = scanner.nextLine();
            scanner.close();
            colorByName(colorName);
        }
    
        private void colorByName(String colorName) {
    
            if (colorName.equals(colorsNames[0])) {
                color = Color.RED;
            } else if (colorName.equals(colorsNames[1])) {
                color = Color.GREEN;
            } else if (colorName.equals(colorsNames[2])) {
                color = Color.BLUE;
            }
        }
    
        private void changing() {
    
            JFrame frame = newJFrame("Color Changer // Main");
            ChangingColorPane ccp = new ChangingColorPane(color);
            frame.add(ccp);
            frame.pack();
            frame.setVisible(true);
            //use swing time to animate
            Timer timer = new Timer(CYCLE_TIME,e->{
                changeColor();
                ccp.setBgColor(color);
                frame.repaint();
            });
            timer.start();
        }
    
        private void changeColor() {
            if (color.equals(Color.RED)) {
                color = Color.GREEN;
            } else if (color.equals(Color.GREEN)) {
                color = Color.BLUE;
            } else if (color.equals(Color.BLUE)) {
                color = Color.RED;
            }
        }
    
        //do custom painting on a JPanel
        class ChangingColorPane extends JPanel{
    
            private static final int W = 400,H = 500;
            private Color bgColor;
            public ChangingColorPane(Color bgColor) {
                this.bgColor = bgColor;
            }
    
            @Override
            protected void paintComponent(Graphics g) {
                super.paintComponent(g);
                g.setColor(bgColor);
                g.fillRect(0,getWidth(),getHeight());
            }
    
            @Override
            public Dimension preferredSize() {
                return new Dimension(W,H);
            }
    
            public void setBgColor(Color bgColor) {
                this.bgColor = bgColor;
            }
        }
    
        public static void main(String[] args) {
            new Colors(1);
        }
    
        private static JFrame newJFrame(String title) {
            JFrame frame = new JFrame(title);
            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            frame.setLocationByPlatform(true);
            frame.setUndecorated(true);
            return frame;
        }
    }

    

输出-:

enter image description here

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

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res