会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132479个问题
Python 全系列/第一阶段:Python入门/Python入门(动画版) 21661楼
Python 全系列/第五阶段:数据库编程/mysql的使用 21662楼

    <title></title>
    <meta name="viewport"
          content="width=device-width,initial-scale=1.0 "/>
    <style>
        *{
            margin: 0;
            padding: 0;

        }
        .items{
            width: 25%;
            height: 450px;
            background-color: red;
            float: left;
            padding: 10px;
            box-sizing: border-box;
        }
        .items>div{
            width: 100%;
            height: 100%;
            background-color: green;
        }
        /*移动端*/
        @media screen and (max-width: 768px) {
            .items{
                width: 50%;
            }

        }
        /*ipad端*/
        @media screen and (min-width: 768px) and (max-width: 992px){
            .items{
                width: 33%;
            }
        }
        /*pc端*/
        @media screen and (min-width: 992px) {
            .items{
                width: 25%;
            }
        }
    </style>
</head>
<body>
<div class="box">
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>
    <div class="items">
        <div></div>
    </div>

</div>
</body>

老师您好,视频中老师说的因为适配器的原因(@media),所以得把css里items的宽度取消,但我发现取消与不取消没有任何区别,这是为什么呢

WEB前端全系列/第一阶段:HTML5+CSS3模块/CSS盒子模型 21664楼
WEB前端全系列/第一阶段:HTML5+CSS3模块/商城官网项目 21665楼
WEB前端全系列/第二十阶段:Vue2企业级项目(旧)/疫情动态实时播报 21666楼
WEB前端全系列/第五阶段:前后端交互/PHP、数据库编程与设计 21667楼
人工智能/第七阶段:机器学习-无监督学习(旧)/EM算法和GMM高斯混合模型 21670楼
JAVA 全系列/第十二阶段:消息中间件(异步消息传递)/ActiveMQ 21671楼
JAVA 全系列/第六阶段:项目管理与SSM框架/SpringMVC旧 21672楼

"""开发画图软件"""
from tkinter import *
from tkinter.colorchooser import *
from tkinter.filedialog import *

# 窗口的宽度和高度
win_width = 900
win_height = 450

class Application(Frame):
    def __init__(self, master=None, bgcolor="#000000"):
        super().__init__(master)
        self.master = master
        self.bgcolor = bgcolor
        self.x = 0
        self.y = 0
        self.fgcolor = "#ff0000"
        self.lastDraw = 0           # 表示最后绘制的图形的id
        self.startDrawFlag = False
        self.colorFlag = False
        self.pack()
        self.createWidget()

    def createWidget(self):
        # 创建绘图区
        self.drawpad = Canvas(root, width=win_width, height=win_height*0.9, bg=self.bgcolor)
        self.drawpad.pack()

        # 创建按钮
        btn_start = Button(root, text="开始", name="start")
        btn_start.pack(side="left", padx="10")
        btn_pen = Button(root, text="画笔", name="pen")
        btn_pen.pack(side="left", padx="10")

        # 事件处理
        btn_pen.bind_class("Button", "<1>", self.eventManager)
        self.drawpad.bind("<ButtonRelease-1>", self.stopDraw)

    def eventManager(self, event):
        name = event.widget.winfo_name()
        print(name)
        if name == "pen":
            self.drawpad.bind("<B1-Motion>", self.myPen)

    def stopDraw(self, event):
        self.startDrawFlag = False
        self.lastDraw = 0

    def startDraw(self, event):
        self.drawpad.delete(self.lastDraw)
        if not self.startDrawFlag:
            self.startDrawFlag = True
            self.x = event.x
            self.y = event.y
            self.colorFlag = True

    def myPen(self, event):
        if not self.colorFlag:
            self.colorCnt = int('0x' + self.fgcolor.strip("#"), 16)
        elif self.colorCnt > 16777215:
            self.colorCnt = 0

        self.startDraw(event)
        self.penColor = "#"+str("%06x" % self.colorCnt)
        self.drawpad.create_line(self.x, self.y, event.x, event.y, fill=self.penColor)
        self.x = event.x
        self.y = event.y
        self.colorCnt += 1


if __name__ == "__main__":
    root = Tk()
    root.geometry(str(win_width)+"x"+str(win_height)+"+600+500")
    root.title("简易记事本")
    app = Application(master=root)
    root.mainloop()

(稍微简化了一下代码方便您查看)


老师,我设置渐变色的思路是先用一个变量获取初始的颜色(初始为:fgcolor="#ff0000"),并去掉"#"保留十六进制的数字,然后把十六进制的数字转为十进制数再加1,再变回十六进制数并高位补0(如果不足6位)再加回"#", 最后把这个新的颜色值传给 self.drawpad.create_line(....., fill=)。

然后结果是这样的:

image.png

请问应该怎么改才能正常渐变?谢谢老师

Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 21673楼
JAVA 全系列/第十阶段:百战旅游网项目/百战旅游网 21675楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637